Power Query: Step Back and See
7 August 2019
Welcome to our Power Query blog. Today, I build a function to add a column to a table.
My imaginary salesperson, Mary, has been busy, and I want to look at how her commission varies daily.
data:image/s3,"s3://crabby-images/aec4a/aec4a3cfbd35df38b4e655f35152d69d10cbe1e3" alt=""
I upload my data into Power Query using ‘From Table’ on the ‘Get & Transform’ section of the Data tab.
data:image/s3,"s3://crabby-images/8fb48/8fb486ff33ec95c5c5cf959f0d64293e48aa6fc4" alt=""
I am going to add an index column, in the ‘Add Column’ tab:
data:image/s3,"s3://crabby-images/3cf9d/3cf9d3a1875c98ea621a8de8b677d14de80caccf" alt=""
I choose to start from 0.
data:image/s3,"s3://crabby-images/7cfb4/7cfb446358e53cdf983d2dca63b18548beee4a2f" alt=""
The step is call ‘Added Index’, which I need to remember for later. I am going to add another index column, this time starting at 1:
data:image/s3,"s3://crabby-images/4d4ce/4d4ceac673cb02c94c19ed7bcf8d2e505b54c18d" alt=""
I am going to merge ‘Added Index’ and’ Added Index.1’ by using some M code in a step. This will allow me to link each row to the previous row. The M function I am using is Table.NestedJoin(), which I used in Power Query: Group Dynamics when I was calculating group share.
data:image/s3,"s3://crabby-images/6e51d/6e51db5e32cb0383e52e227a57a3a29e0289b781" alt=""
The M code I have used is:
= Table.NestedJoin(#"Added Index", {"Employee","Index"}, #"Added Index1", {"Employee","Index.1"}, "Added Index", JoinKind.LeftOuter)
This takes my data with the index that begins at 0 and links it to the table with the index that begins at 1. Therefore, it links all the data to the previous row.
Next, I need to expand some data from my joined table.
data:image/s3,"s3://crabby-images/0bc7e/0bc7e07c432be7dfc9da6a2b0a73b458b8bde3bf" alt=""
In this case, I will ‘Use original column name as prefix’, so I can distinguish between my original and expanded data.
data:image/s3,"s3://crabby-images/d8745/d8745f19e428c785f67fe512cd48995436830821" alt=""
I can now remove the row with null values. I choose to apply a filter.
data:image/s3,"s3://crabby-images/5ec7f/5ec7fc4ebd5ac9541185247dd1e15c2e9d57ee2e" alt=""
Now, I create a custom column to calculate the daily difference in commission.
data:image/s3,"s3://crabby-images/14cac/14cac8fd95106a80895f15b5f01debd624f0de08" alt=""
I click OK to see my new column:
data:image/s3,"s3://crabby-images/b14f3/b14f3d6187ac027134a0578a50f85e1e73bab694" alt=""
I can track my salesperson’s progress in terms of commission, and set targets if I wish.
data:image/s3,"s3://crabby-images/c3ffd/c3ffd60f1055c1b597d1b56b2242140900621a8d" alt=""
I can expand this method to include data from other salespeople.
Come back next time for more ways to use Power Query!