Don't miss your chance to take the Fabric Data Engineer (DP-600) exam for FREE! Find out how by attending the DP-600 session on April 23rd (pacific time), live or on-demand.
Learn moreNext up in the FabCon + SQLCon recap series: The roadmap for Microsoft SQL and Maximizing Developer experiences in Fabric. All sessions are available on-demand after the live show. Register now
Hello, I am looking to add a variance column to my matrix. The variance % calculation would be 1-(column2/column1).
Here is what my report currently looks like. I have a slicer that selects the columns in the matrix and I would need the variance to change based on the months selected.
Here is the result I want:
I have 14 attributes and they would change every year, so I can't hardcode the attribute names into my query.
Solved! Go to Solution.
Hi @bernate
Please try this:
First of all, I create a set of sample data:
Then create a new table with dax:
Table 2 = {1,2,3}
Then add a measure:
MEASURE =
VAR _newvalue =
SELECTEDVALUE ( 'Table 2'[Value] )
VAR _columns =
SWITCH (
_newvalue,
1, MAX ( 'Table'[Column1] ),
2, MAX ( 'Table'[Column2] ),
3, MAX ( 'Table'[Column3] )
)
RETURN
_columns
Then add a matrix and a slicer:
Then add a measure:
% =
VAR _maxvalue =
MAXX ( ALLSELECTED ( 'Table 2' ), 'Table 2'[Value] )
VAR _minvalue =
MINX ( ALLSELECTED ( 'Table 2' ), 'Table 2'[Value] )
RETURN
IF (
MAX ( 'Table 2'[Value] ) = _maxvalue
&& _maxvalue <> _minvalue,
1
- CALCULATE ( 'Table'[Measure], 'Table 2'[Value] = _maxvalue )
/ CALCULATE ( 'Table'[Measure], 'Table 2'[Value] = _minvalue )
)
The result is as follow:
Best Regards
Zhengdong Xu
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
Hi @bernate
Please try this:
First of all, I create a set of sample data:
Then create a new table with dax:
Table 2 = {1,2,3}
Then add a measure:
MEASURE =
VAR _newvalue =
SELECTEDVALUE ( 'Table 2'[Value] )
VAR _columns =
SWITCH (
_newvalue,
1, MAX ( 'Table'[Column1] ),
2, MAX ( 'Table'[Column2] ),
3, MAX ( 'Table'[Column3] )
)
RETURN
_columns
Then add a matrix and a slicer:
Then add a measure:
% =
VAR _maxvalue =
MAXX ( ALLSELECTED ( 'Table 2' ), 'Table 2'[Value] )
VAR _minvalue =
MINX ( ALLSELECTED ( 'Table 2' ), 'Table 2'[Value] )
RETURN
IF (
MAX ( 'Table 2'[Value] ) = _maxvalue
&& _maxvalue <> _minvalue,
1
- CALCULATE ( 'Table'[Measure], 'Table 2'[Value] = _maxvalue )
/ CALCULATE ( 'Table'[Measure], 'Table 2'[Value] = _minvalue )
)
The result is as follow:
Best Regards
Zhengdong Xu
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
@bernate , You switch the grand total with varinace
Measure =
var _min = minx(allselected(Date), Date[Date])
var _max = minx(allselected(Date), Date[Date])
return
if(isinscope(Date[Column month Year]) , [Measure], calculate([Meausre], filetr(Date, eomonth(Date[Date],0) = eomonth(_max,0))) -
calculate([Meausre], filetr(Date, eomonth(Date[Date],0) = eomonth(_min,0))) )
How to Switch Subtotal and Grand Total in Power BI | Power BI Tutorials| isinscope: https://youtu.be/smhIPw3OkKA
If you have recently started exploring Fabric, we'd love to hear how it's going. Your feedback can help with product improvements.
A new Power BI DataViz World Championship is coming this June! Don't miss out on submitting your entry.
Experience the highlights from FabCon & SQLCon, available live and on-demand starting April 14th.
| User | Count |
|---|---|
| 47 | |
| 44 | |
| 40 | |
| 20 | |
| 15 |
| User | Count |
|---|---|
| 70 | |
| 68 | |
| 32 | |
| 27 | |
| 25 |