Microsoft is giving away 50,000 FREE Microsoft Certification exam vouchers. Get Fabric certified for FREE! Learn more
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...
Check out the April 2025 Power BI update to learn about new features.
Explore and share Fabric Notebooks to boost Power BI insights in the new community notebooks gallery.
User | Count |
---|---|
100 | |
65 | |
44 | |
36 | |
36 |