Microsoft Fabric Community Conference 2025, March 31 - April 2, Las Vegas, Nevada. Use code FABINSIDER for a $400 discount.
Register nowGet inspired! Check out the entries from the Power BI DataViz World Championships preliminary rounds and give kudos to your favorites. View the vizzies.
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...
March 31 - April 2, 2025, in Las Vegas, Nevada. Use code FABINSIDER for a $400 discount!
Check out the February 2025 Power BI update to learn about new features.
User | Count |
---|---|
84 | |
79 | |
63 | |
51 | |
30 |
User | Count |
---|---|
116 | |
114 | |
70 | |
66 | |
39 |