Register now to learn Fabric in free live sessions led by the best Microsoft experts. From Apr 16 to May 9, in English and Spanish.
Hi there,
I am looking for a (hopefully) simple DAX measure to solve the following problem.
I have a range consisting of a number of employees, a chosen product, and their savings in each product. In a different table, I need to create a measure that returns the name of the product that contains the largest combined sum of savings. For e.g. Person 1, this would be "Product B", because the 750,000 in Product B exceeds the 500,000 in Product A (had it been opposite, the measure should return "Product A").
I am working in PowerPivot in Excel 2013 and have previously relied on "FIRSTNONBLANK" since the ranges have contained no dublicate values. However, that solution is no longer sufficient. Any help is greatly appreciated.
Thanks!
Solved! Go to Solution.
Hi,
These measures work
Total amount = SUM(Data[Amount])
Top product = FIRSTNONBLANK ( TOPN ( 1, VALUES ( Data[Product] ), [Total amount] ), 1 )
Hope this helps.
Hi,
You may download my PBI file from here.
Hope this helps.
Hi,
These measures work
Total amount = SUM(Data[Amount])
Top product = FIRSTNONBLANK ( TOPN ( 1, VALUES ( Data[Product] ), [Total amount] ), 1 )
Hope this helps.
Apologies for my delayed response, did not have a chance to try and implement the suggestions.
@Ashish_Mathur, you solution worked perfectly, thanks. And likewise, thanks to everyone else who came with suggestions, very appreciated!
You are welcome.
@Ashish_Mathur, quick follow up on this.
Is there an easy way to add a condition to the formula that the ranking is conditional on product not being blank?
Recently had a case where a product was missing, but since it contained the largest value, a blank was returned.
Thanks!
Hi,
Share some data and show the expected result.
Hi,
You may download my PBI file from here.
Hope this helps.
You are welcome.
Hi Ashish,
I have stumbled across this thread and it seems to be very similar to what I am trying to achieve, but I am unable to get the results with your measures.
Scenario:
I would appreciate your help on this one, I am so close yet so far.
Regards
Denny
Hi,
These calculated column formulas work
Required effort per Manager for a ProjectID = CALCULATE(SUM(Data[Required Effort]),FILTER(Data,Data[ProjectID]=EARLIER(Data[ProjectID])&&Data[Project Manager]=EARLIER(Data[Project Manager])))
Max of accumulated required effort = CALCULATE(MAX(Data[Required effort per Manager for a ProjectID]),FILTER(Data,Data[ProjectID]=EARLIER(Data[ProjectID])))
Lead project manager = LOOKUPVALUE(Data[Project Manager],Data[Required effort per Manager for a ProjectID],Data[Max of accumulated required effort],Data[ProjectID],Data[ProjectID])
Hope this helps.
This worked perfectly. Thank you so much. Your knowledge is amazing.
I will have to go back and break each formula down to understand how it works.
You are welcome. Thank you for your kind words. If my previous reply helped, please mark that reply as Answer.
Hi @Anonymous
take a look at the following solution:
Max Amount =
Var _Rank = RANKX(ALL('Table'[Product]),[Sum of Amount],,DESC)
RETURN
IF(_Rank = 1, [Sum of Amount], BLANK())
With kind regards from the town where the legend of the 'Pied Piper of Hamelin' is at home
FrankAT (Proud to be a Datanaut)
Thanks @FrankAT, worked a charm in PowerBI.
However, when trying to convert the formula to Excel PowerPivot, I cannot seem to make it work.
I believe the problem is that Excel will not let you return a text string in a pivot table (unless it is used with e.g. FIRSTNONBLANK).
How do I adjust the formula, so I get the formula to return the correct Product as a text string (I do not need to show the actual amounts in the table, just the product)?
Hi @Anonymous,
Excel and power bi use different logic and structure to store data tables.
Perhaps you can try to convert your table to the query table and use the 'M query' to create a reference query to summarize raw table records.
let
Source = RawTable,//change to your query table name
#"Changed Type" = Table.TransformColumnTypes(Source,{{"Name", type text}, {"Product", type text}, {"Amount", Int64.Type}}),
#"Grouped Rows" = Table.Group(#"Changed Type", {"Name", "Product"}, {{"Total", each List.Sum([Amount]), type nullable number}}),
#"Grouped Rows1" = Table.Group(#"Grouped Rows", {"Name"}, {{"Count", each Table.LastN(_, 1), type table}}),
#"Expanded Count" = Table.ExpandTableColumn(#"Grouped Rows1", "Count", {"Product", "Total"}, {"Product", "Total"})
in
#"Expanded Count"
Regards,
Xiaoxin Sheng
@Anonymous , Based on what I got
Create a rank Measure and filter Rank =1
rank measure =
Rankx(all(Table[product]), calculate(Sum(Table[Amount])))
Thanks @amitchandak, formula seems to work.
However, because I use the names ("Person 1", "Person 2", etc.) as the row filter in the Pivot Table, only one product is currently returned as value. So, the rank function simply returns "1" for all employees, and hence it is not possible to filter.
Any alternative suggestions?
@Anonymous , this how-to measure Rank work. The one I suggested will create a single rank if used with the product and if used with the employee you will get inside the employee.
Try like
RANKX (
FILTER(
ALL( /////////Or allselected
'Table'[employee],
'Table'[product ]
),
'Table'[employee] = MAX('Table'[employee])
),
CALCULATE(SUM('Table'[Amount]))
)
For Rank Refer these links
https://radacad.com/how-to-use-rankx-in-dax-part-2-of-3-calculated-measures
https://radacad.com/how-to-use-rankx-in-dax-part-1-of-3-calculated-columns
https://radacad.com/how-to-use-rankx-in-dax-part-3-of-3-the-finale
https://community.powerbi.com/t5/Community-Blog/Dynamic-TopN-made-easy-with-What-If-Parameter/ba-p/367415
Thanks @amitchandak, I will have a look at the links.
Not sure how the proposed measure works, since it requires taking MAX of employee, which is a string.
Covering the world! 9:00-10:30 AM Sydney, 4:00-5:30 PM CET (Paris/Berlin), 7:00-8:30 PM Mexico City
Check out the April 2024 Power BI update to learn about new features.
User | Count |
---|---|
109 | |
98 | |
77 | |
66 | |
54 |
User | Count |
---|---|
144 | |
104 | |
100 | |
86 | |
64 |