Power Query: Group Text
5 May 2021
Welcome to our Power Query blog. This week, I look at how to modify a grouping statement to accommodate text fields.
I have some data for my imaginary salespeople:
data:image/s3,"s3://crabby-images/ef77f/ef77f4b2e10ca7481128c3f69c8eff92d063bb54" alt=""
They have been selling off some of the old stock, and I want to see the sales figures for each tent type and who has sold it. I start by extracting my data into Power Query using ‘From Table / Range’ in the ‘Get & Transform Data’ section of the Data tab.
data:image/s3,"s3://crabby-images/662c0/662c08abcab9556b0d1a1144b66d204929c9fadd" alt=""
I accept the ‘Create Table’ defaults and view my data in the Power Query Editor.
data:image/s3,"s3://crabby-images/91499/914998bc656927f5624e184a9d7803712078fcf1" alt=""
I am going to group my data using the ‘Group By’ option on the Transform tab.
data:image/s3,"s3://crabby-images/d7b07/d7b07f814a6fc34b02adbf7743aa741abf32ed64" alt=""
I want to group by Tent Type. To begin with, I want to see the sales totals:
data:image/s3,"s3://crabby-images/05b3e/05b3e9696eb5d4db1e87fe7d56c199ee0131a6df" alt=""
I can achieve this by grouping on Tent Type and summing Price.
data:image/s3,"s3://crabby-images/931e7/931e738648bf854bd234d6643cbd8e2aa8e13aed" alt=""
I also want to see which salespeople sold the tents. I go back to the ‘Grouped Rows’ step.
data:image/s3,"s3://crabby-images/63c25/63c25ff2632a0de13fca80f5f61ead55ef885557" alt=""
If I go into the ‘Advanced’ options, I can add another aggregation, but all the operations are aimed at numerical values. However, I am going to go ahead and use a sum, and then amend the M code produced.
data:image/s3,"s3://crabby-images/d7257/d7257cbc4af373722234392b5b90e7d41bc499c8" alt=""
This gives me an error, which is not surprising since I am trying to add up text values!
data:image/s3,"s3://crabby-images/367ec/367ece1bc8d2480c909f2a2452d6044b86c1ce8f" alt=""
Having failed to add up Derek, I look at the M code produced:
= Table.Group(#"Changed Type", {"Tent Type"}, {{"Sales Total", each List.Sum([Price]), type nullable number}, {"Sold By", each List.Sum([Salesperson]), type nullable text}})
I am interested in the code associated with the Sold By column.
{"Sold By", each List.Sum([Salesperson]), type nullable text}
This is currently using List.Sum() to add up the Salesperson column. If I am going to add up text, then I need a text function Text.Combine(). This will allow me to compile a list of the salespeople, separated by a separator of my choice.
{"Sold By", each Text.Combine([Salesperson], “, “), type nullable text}
I have chosen to separate the salespeople with a comma and a space. The full step now looks like this:
= Table.Group(#"Changed Type", {"Tent Type"}, {{"Sales Total", each List.Sum([Price]), type nullable number}, {"Sold By", each Text.Combine([Salesperson], “, “), type nullable text}})
data:image/s3,"s3://crabby-images/a73cb/a73cb374cfc0f1baeabec7c6d0c2c90b3e23728a" alt=""
I now have a list of salespeople in the Sold By column.
Come back next time for more ways to use Power Query!