March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount! Early bird discount ends December 31.
Register NowBe one of the first to start using Fabric Databases. View on-demand sessions with database experts and the Microsoft product team to learn just how easy it is to get started. Watch now
Hello,
I have the following table as a visualisation but without rank column on the right hand side. Please can you tell me how to add this if the other column is a calculated measure? I've seen many examples on the internet that rank referring to an underlying table or calculated column, but haven't seen any that rank a calculated measure - is it even possible?
Area, CalculatedMeasure, CalculatedMeasureRank
North, 504, 2
Midlands, 421, 3
South, 751, 1
South East, 214, 4
Many thanks,
CM
Solved! Go to Solution.
Note that I improved this with a non-trivial case of measure ranking, PBIX attached.
Measure Rank 1 = VAR __current = CALCULATE(MAX([Column1])) VAR __table = SUMMARIZE(ALL(Table1),[Column1],"__Measure",[Measure]) VAR __table1 = ADDCOLUMNS(__table,"__Rank",RANKX(__table,[__Measure])) RETURN MAXX(FILTER(__table1,[Column1]=__current),[__Rank])
Yes, it is possible. Can you post sample source data, measure formula, etc.? Please see this post regarding How to Get Your Question Answered Quickly: https://community.powerbi.com/t5/Community-Blog/How-to-Get-Your-Question-Answered-Quickly/ba-p/38490
The basic process is generally to create a temp table using a VAR that emulates the table you are going to display. You can then use ADDCOLUMNS to create your rank column.
This article may also help although it is not specific to your issue:
https://www.sqlbi.com/articles/use-of-rankx-in-power-bi-measures/
Thanks for trying but I'm afraid it's too complicated. I'll have to export the table into excel and just use the rank function.
Thanks,
CM
I'm not sure how a single line is overly complicated:
Measure Rank = RANKX(ALL(Table1),[Measure])
Or 2 lines for your Standard Deviation question.
Measure StdDev = VAR __table = SUMMARIZE(Table1,[Column1],"__Measure",[Measure]) RETURN STDEVX.P(__table,[__Measure])
But, perhaps it is. People have different definitions of complex.
Note that I improved this with a non-trivial case of measure ranking, PBIX attached.
Measure Rank 1 = VAR __current = CALCULATE(MAX([Column1])) VAR __table = SUMMARIZE(ALL(Table1),[Column1],"__Measure",[Measure]) VAR __table1 = ADDCOLUMNS(__table,"__Rank",RANKX(__table,[__Measure])) RETURN MAXX(FILTER(__table1,[Column1]=__current),[__Rank])
Hi @CloudMonkey
As tested, Greg_Deckler's solution works, does it exactly meet your goal?
If so, could you kindly mark it as a solution?
Best Regards
Maggie
March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!
Your insights matter. That’s why we created a quick survey to learn about your experience finding answers to technical questions.
Arun Ulag shares exciting details about the Microsoft Fabric Conference 2025, which will be held in Las Vegas, NV.
User | Count |
---|---|
133 | |
90 | |
88 | |
64 | |
58 |
User | Count |
---|---|
201 | |
137 | |
107 | |
70 | |
68 |