Power Query: See it, Save it, Sort it - Part 5
15 June 2022
Welcome to our Power Query blog. This week, I amend my merge to filter my data.
In Power Query: See it, Save it, Sort it – Part 1, I started with some data for my imaginary salespeople:
data:image/s3,"s3://crabby-images/736c2/736c20f9defd9fad99c9bcc4bdaa0c893a9c1d49" alt=""
and extracted it into Power Query, in order to perform some transformations.
data:image/s3,"s3://crabby-images/05b97/05b97426918b9f40b719574874fca903f311635b" alt=""
Last week, I chose to merge the table with itself on Date, and chose a ‘Full Outer’ join:
data:image/s3,"s3://crabby-images/7317d/7317dbb3f651f417e90c6064e3e51b9255f451a1" alt=""
This left me with a column of tables, which I expanded to create a Date.1 column.
data:image/s3,"s3://crabby-images/afc3d/afc3dde4d03638f53669ca2dcd91cd32cb2b6551" alt=""
This time, I go back to my ‘Merged Queries’ step:
data:image/s3,"s3://crabby-images/757ef/757ef4e502498f6c9e15e63d5aa1bfc73216ec02" alt=""
The M code for this step is:
= Table.NestedJoin(#"Sorted Rows", {"Date"}, #"Sorted Rows", {"Date"}, "Sorted Rows", JoinKind.FullOuter)
where ‘Sorted Rows’ is the name of the previous step. If I replace the second ‘Sorted Rows’ with ‘Changed Type’, this will give me Sales_Transactions before I appended the data:
data:image/s3,"s3://crabby-images/7f848/7f8489b4d5e74f4f9d8bda4f29bde30b0e34cef9" alt=""
I amend the M code in the ‘Merged Queries’ step by editing the code in the Formula bar:
= Table.NestedJoin(#"Sorted Rows", {"Date"}, #"Changed Type", {"Date"}, "Sorted Rows", JoinKind.FullOuter)
When I enter this change, nothing seems to happen:
data:image/s3,"s3://crabby-images/9094c/9094c124c814ace97c8fbae157f05a6117484cb9" alt=""
However, if I go to the ‘Expand Sorted Rows’ step, I can see that not all values in Date.1 are now populated:
data:image/s3,"s3://crabby-images/8d5ec/8d5ec61b376179bc39e96ec562d7a66bde768d65" alt=""
The rows which have null in Date.1 are the appended data from Full_Dates that I need to keep, along with the original data from Sales_Transactions:
I can do this by creating a flag by adding a ‘Conditional Column’ from the ‘Add Column’ tab:
data:image/s3,"s3://crabby-images/7df73/7df73c3fd5ccb65529c4cc6c5ef29931a718b8ff" alt=""
This brings up a dialog, where I can enter the conditions for the row to be kept.
data:image/s3,"s3://crabby-images/3329c/3329c9a312b9bcbee46148dfb698a8dbe3267278" alt=""
I want to keep the rows where Amount is not null or Date.1 is null. This ensures I only keep the appended rows from Full_Dates if I don’t already have data for that day.
data:image/s3,"s3://crabby-images/aab87/aab874c59211b0a1a16e0e313549994145bb67f4" alt=""
Now I can filter on Keep Row and keep all rows where it is one [1].
data:image/s3,"s3://crabby-images/f94e8/f94e8014b792a1fe92c3e70d193a729d346c2f61" alt=""
This gives me the data I need, and I right-click on Keep Row and select Remove.
data:image/s3,"s3://crabby-images/3fb81/3fb817071a2870091edfbde02ca577aa1a58ba2a" alt=""
Next time I will continue transforming my data.
Come back next time for more ways to use Power Query!