Don't miss your chance to take exam DP-600 or DP-700 on us!
Request nowLearn from the best! Meet the four finalists headed to the FINALS of the Power BI Dataviz World Championships! Register now
I need to add a column that displays the change percentage between the "BeforeChange" and "AfterChange" columns in a matrix. Is there a way to do this within the matrix visual or does anyone have alternate ways to achieve this end result?
Thank you in advance!
Solved! Go to Solution.
@lbendlin Thanks for your contribution on this thread.
Hi @BrazenTelephone ,
You can follow the steps below to get it:
1. Select the matrix visual and navigate to format pane. Toggle on the option "Column subtotals" and change Subtotal label as "Percent Change" just as shown in below screenshot
2. Create another new 5 measures to replace the orignal measures
New_AvgStep1_duration =
VAR _before =
SUMX ( FILTER ( 'Table', [Period] = "BeforeChange" ), [AvgStep1_duration] )
VAR _after =
SUMX ( FILTER ( 'Table', [Period] = "WithChange" ), [AvgStep1_duration] )
VAR _percent =
DIVIDE ( _after - _before, _before )
RETURN
IF ( ISINSCOPE ( 'Table'[Period] ), [AvgStep1_duration], _percent )New_AvgStep2_duration =
VAR _before =
SUMX ( FILTER ( 'Table', [Period] = "BeforeChange" ), [AvgStep2_duration] )
VAR _after =
SUMX ( FILTER ( 'Table', [Period] = "WithChange" ), [AvgStep2_duration] )
VAR _percent =
DIVIDE ( _after - _before, _before )
RETURN
IF ( ISINSCOPE ( 'Table'[Period] ), [AvgStep2_duration], _percent )New_AvgStep3_duration =
VAR _before =
SUMX ( FILTER ( 'Table', [Period] = "BeforeChange" ), [AvgStep3_duration] )
VAR _after =
SUMX ( FILTER ( 'Table', [Period] = "WithChange" ), [AvgStep3_duration] )
VAR _percent =
DIVIDE ( _after - _before, _before )
RETURN
IF ( ISINSCOPE ( 'Table'[Period] ), [AvgStep3_duration], _percent )New_AvgStep4_duration =
VAR _before =
SUMX ( FILTER ( 'Table', [Period] = "BeforeChange" ), [AvgStep4_duration] )
VAR _after =
SUMX ( FILTER ( 'Table', [Period] = "WithChange" ), [AvgStep4_duration] )
VAR _percent =
DIVIDE ( _after - _before, _before )
RETURN
IF ( ISINSCOPE ( 'Table'[Period] ), [AvgStep4_duration], _percent )New_AvgTotalProcess_duration =
VAR _before =
SUMX ( FILTER ( 'Table', [Period] = "BeforeChange" ), [AvgTotalProcess_duration] )
VAR _after =
SUMX ( FILTER ( 'Table', [Period] = "WithChange" ), [AvgTotalProcess_duration] )
VAR _percent =
DIVIDE ( _after - _before, _before )
RETURN
IF ( ISINSCOPE ( 'Table'[Period] ), [AvgTotalProcess_duration], _percent )
3. Replace the original measures with the above new measures
If the above one can't help you figure out, please provide some info just as suggested by @lbendlin .
Best Regards
@lbendlin Thanks for your contribution on this thread.
Hi @BrazenTelephone ,
You can follow the steps below to get it:
1. Select the matrix visual and navigate to format pane. Toggle on the option "Column subtotals" and change Subtotal label as "Percent Change" just as shown in below screenshot
2. Create another new 5 measures to replace the orignal measures
New_AvgStep1_duration =
VAR _before =
SUMX ( FILTER ( 'Table', [Period] = "BeforeChange" ), [AvgStep1_duration] )
VAR _after =
SUMX ( FILTER ( 'Table', [Period] = "WithChange" ), [AvgStep1_duration] )
VAR _percent =
DIVIDE ( _after - _before, _before )
RETURN
IF ( ISINSCOPE ( 'Table'[Period] ), [AvgStep1_duration], _percent )New_AvgStep2_duration =
VAR _before =
SUMX ( FILTER ( 'Table', [Period] = "BeforeChange" ), [AvgStep2_duration] )
VAR _after =
SUMX ( FILTER ( 'Table', [Period] = "WithChange" ), [AvgStep2_duration] )
VAR _percent =
DIVIDE ( _after - _before, _before )
RETURN
IF ( ISINSCOPE ( 'Table'[Period] ), [AvgStep2_duration], _percent )New_AvgStep3_duration =
VAR _before =
SUMX ( FILTER ( 'Table', [Period] = "BeforeChange" ), [AvgStep3_duration] )
VAR _after =
SUMX ( FILTER ( 'Table', [Period] = "WithChange" ), [AvgStep3_duration] )
VAR _percent =
DIVIDE ( _after - _before, _before )
RETURN
IF ( ISINSCOPE ( 'Table'[Period] ), [AvgStep3_duration], _percent )New_AvgStep4_duration =
VAR _before =
SUMX ( FILTER ( 'Table', [Period] = "BeforeChange" ), [AvgStep4_duration] )
VAR _after =
SUMX ( FILTER ( 'Table', [Period] = "WithChange" ), [AvgStep4_duration] )
VAR _percent =
DIVIDE ( _after - _before, _before )
RETURN
IF ( ISINSCOPE ( 'Table'[Period] ), [AvgStep4_duration], _percent )New_AvgTotalProcess_duration =
VAR _before =
SUMX ( FILTER ( 'Table', [Period] = "BeforeChange" ), [AvgTotalProcess_duration] )
VAR _after =
SUMX ( FILTER ( 'Table', [Period] = "WithChange" ), [AvgTotalProcess_duration] )
VAR _percent =
DIVIDE ( _after - _before, _before )
RETURN
IF ( ISINSCOPE ( 'Table'[Period] ), [AvgTotalProcess_duration], _percent )
3. Replace the original measures with the above new measures
If the above one can't help you figure out, please provide some info just as suggested by @lbendlin .
Best Regards
You can repurpose the Column Total column for that measure.
Please provide sample data that covers your issue or question completely, in a usable format (not as a screenshot).
Do not include sensitive information or anything not related to the issue or question.
If you are unsure how to upload data please refer to https://community.fabric.microsoft.com/t5/Community-Blog/How-to-provide-sample-data-in-the-Power-BI-...
Please show the expected outcome based on the sample data you provided.
Want faster answers? https://community.fabric.microsoft.com/t5/Desktop/How-to-Get-Your-Question-Answered-Quickly/m-p/1447...
Share feedback directly with Fabric product managers, participate in targeted research studies and influence the Fabric roadmap.
Check out the February 2026 Power BI update to learn about new features.
| User | Count |
|---|---|
| 51 | |
| 40 | |
| 37 | |
| 14 | |
| 14 |
| User | Count |
|---|---|
| 85 | |
| 69 | |
| 38 | |
| 29 | |
| 27 |