Join us at FabCon Atlanta from March 16 - 20, 2026, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM.
Register now!The Power BI Data Visualization World Championships is back! Get ahead of the game and start preparing now! Learn more
Hi guys,
I would like to create a TOPN measure that sums up the revenues generated by the 2 most high-selling products. However, my table (a simplified version below) contains duplicates.
Is it possible to create a TOPN measure for revenue (column 3) that recognizes duplicates by product ID (column 1)?
Input:
| Product ID | Revenue EURO |
| A | 100 |
| A | 100 |
| B | 50 |
| C | 20 |
| D | 10 |
My desired output would be a TOPN measure that gives the result 250 for the top 2 most high selling products, in this instance: A generates 200 EURO and B 50 EURO.
So the measure should on the one hand recognize duplicates (here: A) but still summarize the revenue for duplicate products.
Hope that is not too confusing!
Solved! Go to Solution.
Please try this expression in a measure to get your desired result.
Top 2 Sum =
VAR summary =
ADDCOLUMNS (
VALUES ( 'Table'[Product ID] ),
"@total", CALCULATE ( SUM ( 'Table'[Revenue EURO] ) )
)
RETURN
SUMX ( TOPN ( 2, summary, [@total], DESC ), [@total] )
If this works for you, please mark it as the solution. Kudos are appreciated too. Please let me know if not.
Regards,
Pat
To learn more about Power BI, follow me on Twitter or subscribe on YouTube.
Hi @Anonymous ,
According to my understanding, you want to sum the top2 values when there are duplicate values, right?
You could use the following formula:
rank =
RANKX (
ALLSELECTED ( 'Table' ),
CALCULATE ( SUM ( 'Table'[sumColumn] ) ),
,
DESC,
DENSE
)sumTop2 =
CALCULATE (
SUM ( 'Table'[Revenue EURO] ),
FILTER ( ALL ( 'Table' ), [rank] <= 2 )
)My visualization looks like this:
Is the result what you want? If not, please upload some data samples and expected output.
Please do mask sensitive data before uploading.
Best Regards,
Eyelyn Qin
Please try this expression in a measure to get your desired result.
Top 2 Sum =
VAR summary =
ADDCOLUMNS (
VALUES ( 'Table'[Product ID] ),
"@total", CALCULATE ( SUM ( 'Table'[Revenue EURO] ) )
)
RETURN
SUMX ( TOPN ( 2, summary, [@total], DESC ), [@total] )
If this works for you, please mark it as the solution. Kudos are appreciated too. Please let me know if not.
Regards,
Pat
To learn more about Power BI, follow me on Twitter or subscribe on YouTube.
Copying DAX from this post? Click here for a hack to quickly replace it with your own table names
Has this post solved your problem? Please Accept as Solution so that others can find it quickly and to let the community know your problem has been solved.
If you found this post helpful, please give Kudos C
I work as a Microsoft trainer and consultant, specialising in Power BI and Power Query.
www.excelwithallison.com
Hi @Anonymous
Create a measure as
Measure = CALCULATE(SUMX(TOPN(2,VALUES('Table'[Revenue]),'Table'[Revenue],DESC),'Table'[Revenue])) Did I answer your question? Mark my post as a solution! Appreciate your Kudos!!
Regards,
Pranit
The Power BI Data Visualization World Championships is back! Get ahead of the game and start preparing now!
| User | Count |
|---|---|
| 37 | |
| 37 | |
| 33 | |
| 32 | |
| 29 |
| User | Count |
|---|---|
| 130 | |
| 88 | |
| 82 | |
| 68 | |
| 64 |