Power Query: Fascinating Filters
15 May 2019
Welcome to our Power Query blog. Today, I am going to look at how Power Query turns a tricky transformation into a simple task.
I am worried about the expenses my imaginary salespeople are incurring. I have identified target areas that I need to analyse. I have a query with my target areas, and I have a query with my salespeople’s data – I want to filter their data using my target area query.
data:image/s3,"s3://crabby-images/317f7/317f7b1ead20e9115c6044c7e3bbc248a4186cc0" alt=""
I create two queries ‘From Table’ in the ‘Get & Transform’ section of the ‘Data’ tab.
data:image/s3,"s3://crabby-images/a3379/a33794e590d26ab13218dbbe304e13a39a2b5495" alt=""
I am in the ‘Salespeople_Expenses’ query, and I can see the ‘Target_Expenses’ query in the left-hand pane. I want to filter Expense by the column in query ‘Target_Expenses’ (I have called the column Target Expenses). The method I am going to use is to treat Expense like a list. I used similar functionality in Power Query: Words Are Key, but this time, instead of List.ContainsAny(), I am going to use List.Contains():
List.Contains(list as list, value as any, optional equationcriteria as any) as logical
This returns true if a value is found in a list. I also have the option of specifying a condition (equationcriteria), but I won’t need that optional parameter in this example.
In order to get the M code needed to apply a filter, I first apply a standard filter to Expense.
data:image/s3,"s3://crabby-images/c54c0/c54c0e9492fb4f0f055918fb194b95692ccc620b" alt=""
I use the downward arrow icon next to the title of Expense, and I opt to filter on the value ‘Petrol’.
data:image/s3,"s3://crabby-images/83eb0/83eb04d521399e3907d5bc2b0b856af39acdc4b6" alt=""
This gives me the generated M code:
= Table.SelectRows(#"Renamed Columns", each [Expense] = "Petrol")
I can edit this to use List.Contains():
= Table.SelectRows(#"Renamed Columns", each List.Contains(Target_Expenses[Target Expenses], [Expense]))
data:image/s3,"s3://crabby-images/ade25/ade255f7ea649f6163ed01aa7947b6fbaadad621" alt=""
When I click on the tick (or press RETURN), I expect to see only those expenses that I am targeting.
data:image/s3,"s3://crabby-images/fa410/fa41078aa2274f16f8b2bf0671def0f6f3e25a3e" alt=""
I can now focus on the expenses that concern me, so I choose to ‘Close & Load’ my query to a worksheet in my Excel workbook. If other expense types are called into question, they can be added to my original worksheet.
data:image/s3,"s3://crabby-images/17555/1755560e0976b1e8d3a2c5816f6658764707b014" alt=""
I refresh my query to see the results.
data:image/s3,"s3://crabby-images/50403/504032cfbaf01df186e4ad1e2c41ea13a590212a" alt=""
The latest expense code to cause concern has been added. I have renamed my sheets to make the functionality clearer.
Come back next time for more ways to use Power Query!