Power Query: Top Two
13 May 2020
Welcome to our Power Query blog. This week, I look at splitting my data into the top two (for example) and the rest.
I have some data from my imaginary salespeople that I used in Power Query: Group Functions.
data:image/s3,"s3://crabby-images/df68e/df68e7bf79d89e89b185f5e0ad9da252924d572a" alt=""
This time, I want to give the commission total for 2019 to my two top salespeople, and then show an average for everyone else.
I start by extracting my data into Power Query, by using ‘From Table’ in the ‘Get & Transform’ section of the Data tab.
data:image/s3,"s3://crabby-images/a85f3/a85f3640f2f933cd7cba301f313edcf149f0c29a" alt=""
I need to find the total commission for each salesperson, so I use the grouping functionality on the ‘Transform’ tab. I group by Salesperson and sum the Commission.
data:image/s3,"s3://crabby-images/af3de/af3de5180a6db7727c2131441d6d3124cb677b55" alt=""
I can now apply a descending sort on Commission to get my top two salespeople.
data:image/s3,"s3://crabby-images/80489/80489a0c2129a955db37d8007a2c9c78f1f8cff7" alt=""
To get my top two salespeople, I can just take the top two rows.
data:image/s3,"s3://crabby-images/db5c7/db5c776f5ff9d4a66695b256aef406405eaf9983" alt=""
I choose to use the ‘Keep Rows’ functionality on the Home tab. This is more flexible than removing the bottom rows, as I don’t have to specify how many rows to remove.
data:image/s3,"s3://crabby-images/48edf/48edf6ed1799837dafa0c3d89fc4c842a8061168" alt=""
I now have my top two, and I am going to convert my salespeople column to a list by using the ‘Convert to List’ functionality on the Transform tab. I will use this later to reassemble my data.
data:image/s3,"s3://crabby-images/4eab8/4eab85f7a021f376a9c29b1a30145bf8995dd3d6" alt=""
I create my list:
data:image/s3,"s3://crabby-images/cd8f2/cd8f2e76dcb2298954eb52022b86ac8d7e57869b" alt=""
I rename the step to create my list TopTwo. Now, I need to deal with the others. I create a new step which refers to the data before I removed the bottom columns.
data:image/s3,"s3://crabby-images/077ac/077ac1462153e4a07f8c2fdcfa38d3daec05cfb7" alt=""
The M code I have used is:
= #"Sorted Rows"
which accesses the data before I removed the bottom rows. This time, I need to remove the top rows using the remove rows functionality on the Home tab.
data:image/s3,"s3://crabby-images/305fa/305faeee0d770df83dc67e882ada6494f7eeecfa" alt=""
I remove the top two rows. To get the average to appear in each column, I will use grouping, but I need to group using a constant so that I can sum the commissions. To do this, I add a custom column from the ‘Add Column’ tab, which always has the same value. The value I am going to use is “Others”, viz.
data:image/s3,"s3://crabby-images/a27f1/a27f147fb7cf4fdfb491dcb78cadc4c1d2ee867d" alt=""
I can now group my data from the Transform tab.
data:image/s3,"s3://crabby-images/18d62/18d62e70c3913172c237d435afd45ad19538a7a0" alt=""
I group by Custom and create a new Commission 2019 column (yes, I know we are in 2020!) which will contain the average.
data:image/s3,"s3://crabby-images/d48a7/d48a781836ef7fea4e9510cdf68c43ecf892b503" alt=""
I have my data for the others, so I rename the step to Others and rename Custom to Salesperson. I am now ready to reassemble my data.
As I did earlier, I create a step to get back to my full data before I removed any rows. This will allow me to keep any columns that do not directly pertain to the calculation, and makes the method more flexible.
data:image/s3,"s3://crabby-images/50767/5076739cbeed9190e2a6d20303dd63f713af2dad" alt=""
I need to select those rows which are associated with my top two.
data:image/s3,"s3://crabby-images/925e1/925e100e26d51943031e9d85ae71b2e492212dea" alt=""
The M code I have used is:
= Table.SelectRows(Custom2, each (List.Contains(TopTwo,[Salesperson])=true ))
data:image/s3,"s3://crabby-images/5ffc8/5ffc83f76f125df33829d81cb765c629f0ee896f" alt=""
This gives me the data for my top two. Now I need to add my ‘others’. I do this by merging my table to itself, and then changing the M code generated.
data:image/s3,"s3://crabby-images/d87d6/d87d6ccc3e6221f9a5ba8d3bde5967dd4f759f74" alt=""
I check the M code generated.
data:image/s3,"s3://crabby-images/e3c02/e3c0281c3d40889e5c849fb18b3e24c0b4aeb02c" alt=""
I have the M code
= Table.Combine({Custom3, Custom3})
I change this to
= Table.Combine({Custom3, Others})
data:image/s3,"s3://crabby-images/bdd5a/bdd5ab8670cfb7826acbce8ab4cf2e07bbe307b2" alt=""
I now have my data in the form I wanted, with my top two salespeople and the others combined into one average commission.
Come back next time for more ways to use Power Query!