Power Query: Top Tied
2 October 2019
Welcome to our Power Query blog. Today, I look at how to rank tied places.
The figures have come in for my imaginary salespeople:
data:image/s3,"s3://crabby-images/28a4d/28a4d7c7f2c683143e960cb95c767523ef89a2ad" alt=""
Since the top salesperson gets a bonus, I want to indicate clearly who is top. This principle can be expanded to include as many places as I like. I pull my data into Power Query using ‘From Table’ from the ‘Get & Transform’ section of the ‘Data’ tab.
data:image/s3,"s3://crabby-images/ee3b7/ee3b766ed3ff8b0da256a1d86308119f29e3fe86" alt=""
I sort my data by July Sales using the arrow next to the column name. I then choose to add an index column from the ‘Add Column’ tab (starting at zero).
data:image/s3,"s3://crabby-images/6e956/6e956a3a40b58e7ba3f09d6ea7edfc1ffafee84f" alt=""
I can now create a custom column, which will allocate the top place if Index is 0.
data:image/s3,"s3://crabby-images/8d494/8d49478a92eedd841ec9bc6f27281786b0a36508" alt=""
I click OK, and I can see the top salesperson, Mary.
data:image/s3,"s3://crabby-images/b3201/b3201c88730d5764e6ca663c19b409ae7d12ba82" alt=""
I ‘Close & Load’ this to Excel from the ‘Home’ tab.
data:image/s3,"s3://crabby-images/28695/28695ab57e7405ff496d092d1e7049e2bbf706c9" alt=""
However, I have some late results, so I need to go back to my source data.
data:image/s3,"s3://crabby-images/475ca/475ca551d399cd210ed559596513c6288a1a1481" alt=""
Kevin’s results have been added, so I check the results of my query.
data:image/s3,"s3://crabby-images/402d1/402d1a3175186fafe09f25fcb6c86f533e04cc08" alt=""
Well that doesn’t seem fair: Kevin has not reached the bonus category. I need to amend my query.
data:image/s3,"s3://crabby-images/07b82/07b8254e38821dbb39bfab237b0401b85ccea6de" alt=""
Since the index is incremented for each salesperson, Kevin is not getting the correct ranking. I need to group by July Sales. I can do this using ‘Group By’ on the ‘Transform’ tab.
data:image/s3,"s3://crabby-images/b797a/b797ab2b1ecfde47c5c735849ff87173547f84f3" alt=""
I also add a new index column.
data:image/s3,"s3://crabby-images/ff055/ff055d0cd953e9e9f1c6521cd38671b4c961158d" alt=""
I can now add a new conditional column which will indicate top ranking.
data:image/s3,"s3://crabby-images/a2acd/a2acd60477100c08fdeb3c4b7b139ea6e313f065" alt=""
I need to link this back to my salespeople. I will link this table to the table I had at step ‘Added Conditional Column’, before I grouped my data. If I look at the ‘Home’ tab, I have the option to ‘Merge Queries’.
data:image/s3,"s3://crabby-images/cd636/cd636b4467050bb1624c0d0838be7801f92b2fe0" alt=""
Since I only have one query, I have to link it to itself, but I can amend the M code later.
data:image/s3,"s3://crabby-images/20763/207633b873d33455349043bb91e650e0ebbb7eae" alt=""
I link on July Sales, since that will eventually give me all the salespeople.
data:image/s3,"s3://crabby-images/42451/42451bd68d45bbdbf09cd6aa0d9908a18cf09767" alt=""
I have generated the following M code:
= Table.NestedJoin(#"Added Conditional Column1", {"July Sales"}, #"Added Conditional Column1", {"July Sales"}, "Added Conditional Column1", JoinKind.LeftOuter)
This joins the query to itself at the same point, but I will amend it to link back to the earlier step.
= Table.NestedJoin(#"Added Conditional Column1", {"July Sales"}, #"Added Conditional Column", {"July Sales"}, "Merged Queries", JoinKind.LeftOuter)
Thanks to the similar step names, I only have to change the second “Added Conditional Column1” to “Added Conditional Column”. I call my new column Merged Queries.
data:image/s3,"s3://crabby-images/5ac18/5ac18ed61786f0d2cbb2b78650c5adcb5a040a5a" alt=""
I can expand my new column to get all the rows back, and I will choose to retrieve only the name of the salesperson from Merged Queries.
data:image/s3,"s3://crabby-images/5207d/5207d85389ef79044618c4b8e11947002c85bbe5" alt=""
I can now see that Mary and Kevin are both Top, and they will get their bonus! I remove Index and Count and reorganise my data before I ‘Close & Load’ to Excel.
data:image/s3,"s3://crabby-images/b55af/b55af1512e0d0db02fc12f77556bcd42ae46058c" alt=""
To check the query for more data, I enter the details for more salespeople.
data:image/s3,"s3://crabby-images/6f420/6f420b81c9278c6e8037e8c8e42e6470224b768e" alt=""
When I refresh my query, the results are clear.
data:image/s3,"s3://crabby-images/fba1f/fba1fb3f310b7e3aa1742076a75c3212a676858d" alt=""
I clearly have lots of top salespeople due for a bonus!
Come back next time for more ways to use Power Query!