Power Query: Emerging from a Muddle
3 March 2021
Welcome to our Power Query blog. This week, I look at a more efficient way of merging the data from last week, again when there is not a clear link between the tables,
I begin by repeating the scenario from last time. I have some sales contact data for my imaginary business. Unfortunately, I have some complaints and I want to allocate them to the correct salesperson. I have the date of the complaint and also the date the salesperson took over as the primary.
data:image/s3,"s3://crabby-images/e45bf/e45bf75d6192675db5d98e3f98fc46feb7b209be" alt=""
I start by extracting my data to Power Query. I have two tables. I click somewhere in my first table, and I choose ‘From Table/Range’ on the ‘Get & Transform’ section of the Data tab.
data:image/s3,"s3://crabby-images/33d14/33d147476e7c07b1fe04179b3aa09325e85b200e" alt=""
I take the usual defaults and click OK.
data:image/s3,"s3://crabby-images/c83a8/c83a88701acff5daf5220752c3f61c086d1585f8" alt=""
I ‘Close & Load’ my first table and repeat this process for the other table.
data:image/s3,"s3://crabby-images/bb0e1/bb0e11c14df46fa281736a6ed8690685813913fe" alt=""
I now have two tables, which I have called ‘Key Salesperson’ and Complaints. At this point last week, I used a full outer join to connect my tables. This week, I am going to join them conditionally. I will write a function to get the correct salesperson for each complaint.
I start with my ‘Key Salesperson’ table. Considering this table from the perspective of the Complaints table, I will need to know which salesperson was the primary contact for a given Complaint Date, so I start by generating some of the M code I will need. I will need to find the salesperson who takes over before the date of the complaint.
data:image/s3,"s3://crabby-images/2287c/2287c65c98ffc6b0de004c9fb9c90e0f2a85f5af" alt=""
I filter on the date, and for now, I just choose to filter before one of the dates already in the table. It doesn’t matter what date I use at this point; I just need the syntax. My next consideration is that this could return more than one salesperson, and I want to get just the latest one.
data:image/s3,"s3://crabby-images/18910/18910fd6c8bb803f3006684b62c4f222b4f01109" alt=""
I need to sort the data in reverse date order, to give me the most recent record at the top.
Finally, I drill down into the top value to ensure that my function will return the name of the salesperson.
data:image/s3,"s3://crabby-images/2f242/2f242637cd89df1963c72e0c3f684db5a4e9b216" alt=""
This gives me a single value:
data:image/s3,"s3://crabby-images/e2f59/e2f59c6f6fe2ec72ba0dec892b2e287e2c5b5036" alt=""
Now I have the code I need; I am going to turn this into a function.
data:image/s3,"s3://crabby-images/ad595/ad595aee0568c1a7f774ae2987c1160ce542a553" alt=""
The code I have in the advanced editor so far is:
let
Source = #"Key Salesperson",
#"Filtered Rows" = Table.SelectRows(Source, each [Date] < #datetime(2020, 1, 15, 0, 0, 0)),
#"Sorted Rows" = Table.Sort(#"Filtered Rows",{{"Date", Order.Descending}}),
#"Primary Sales Person" = #"Sorted Rows"{0}[Primary Sales Person]
in
#"Primary Sales Person"
I will pass a parameter p_complaintdate, which I will use instead of the hardcoded date in the #Filtered Rows step.
data:image/s3,"s3://crabby-images/96178/96178ccca0aff47523297d1b2d123b2cdc57af54" alt=""
The M code is now:
(p_complaintdate as date) =>
let
Source = #"Key Salesperson",
#"Filtered Rows" = Table.SelectRows(Source, each [Date] < p_complaintdate),
#"Sorted Rows" = Table.Sort(#"Filtered Rows",{{"Date", Order.Descending}}),
#"Primary Sales Person" = #"Sorted Rows"{0}[Primary Sales Person]
in
#"Primary Sales Person"
I can then save this as a function fn_salesperson and go back to my Complaints table.
data:image/s3,"s3://crabby-images/1fabf/1fabfdc61bee396eee7fb0415bfddfdd7a4f2af7" alt=""
I am going to add a column from the ‘Add Column’ tab to ‘Invoke Custom Function’.
data:image/s3,"s3://crabby-images/fce73/fce734a297524375122fae37e4bbf5cb4482c017" alt=""
I choose my function and select to use Complaint Date as the parameter.
data:image/s3,"s3://crabby-images/89783/897837094364b44435baadf328d998dc2a6c6a98" alt=""
This gives me the correct salesperson for each complaint.
Come back next time for more ways to use Power Query!