Power Query: M(erry) Christmas
25 December 2024
Welcome to our Power Query blog. This week, I take a break from all things fuzzy to help out a familiar face.
I have received a request from a Mr. S Claus, who is having some issues with his workforce. The Elf Service are complaining about being continually shelved, and Mr. Claus has resorted to asking the reindeer to create a Present List. They are refusing to pull together, so he has the following Table:
data:image/s3,"s3://crabby-images/ca384/ca384811045ff9b8e5597165b4cae73edbbe8e72" alt=""
He would like one list, and to avoid upsetting the Elves again, he needs any duplicates to be removed. Since he’s quite busy, he would like me to automate this process.
I start by naming the Table SC_List, by changing ‘Table Name:’ in the ‘Table Design’ tab. I right-click on the Table and choose to ‘Get Data from Table/Range’. I now have a query SC_List:
data:image/s3,"s3://crabby-images/d14bf/d14bf4a5fe35e17bc580453f1fbdb432c0b990a3" alt=""
I may remove the ‘Changed Type’ step, as all my data is text, and I will not be keeping these columns. I note that if I right-click on a column header, I have the option to ‘Add as New Query’:
data:image/s3,"s3://crabby-images/6ec7f/6ec7f9851f640c69f376f8c81ad93ef56c6fc2ba" alt=""
If I did this to each column, I could create nine [9] queries, which may then be appended together.
Let’s look at the M code generated when I create a query for Dasher:
data:image/s3,"s3://crabby-images/b701a/b701a939b042626c2afdebb1e026f5bc0df6533d" alt=""
The M code is simply:
= Source[Dasher]
This gives me an idea. Rather than creating lots of queries and appending them, I may add lists together using the function List.Combine() (which I last looked at a long time ago in ‘All Over Running Totals’). For example, to combine the Dasher and Rudolf columns I could use the M code:
= List.Combine({Source[Dasher], Source[Rudolf]})
data:image/s3,"s3://crabby-images/22c47/22c47c2999a806ba616e85c9ac9efc853082931e" alt=""
This is looking good; let’s add the rest of the herd.
data:image/s3,"s3://crabby-images/07434/074343a9a8a1d2bbd2cf757522700945f1c49108" alt=""
The M code is:
= List.Combine({Source[Dasher], Source[Prancer], Source[Dancer], Source[Vixen], Source[Donner], Source[Blitzen], Source[Cupid], Source[Comet],Source[Rudolf]})
Perfect, 90 rows are now on the list! Now, I need to get rid of the duplicates. I can do this without adding another step. Instead of List.Combine(), I use List.Union():
data:image/s3,"s3://crabby-images/26ecb/26ecb0d87716f879cd6cd7904fd167477a850b0f" alt=""
The M code is now
= List.Union({Source[Dasher], Source[Prancer], Source[Dancer], Source[Vixen], Source[Donner], Source[Blitzen], Source[Cupid], Source[Comet],Source[Rudolf]})
For this example, List.Union() is ideal as it extracts items from all the lists but only shows them once. I rename the query SC_Elves_List, and ‘Close & Load’ from the Home tab:
data:image/s3,"s3://crabby-images/5923e/5923e384c2e33ee4cfef111918992e0be1de7647" alt=""
The list is even in the Elves favourite colour! When Rudolf decides to add more ‘toys’:
data:image/s3,"s3://crabby-images/8062d/8062dd0dfb95d172c5eb40307daef571d6b01232" alt=""
I simply refresh the query and the new rows appear:
data:image/s3,"s3://crabby-images/a0c2c/a0c2c53ba948b91d7c3a4eace0c3de5ebf675117" alt=""
Mr. Claus is happy (actually, quite jolly 😉). Merry Christmas!
Come back next time for more ways to use Power Query!