Power Query: Filtering of Choice Part 3
11 September 2024
Welcome to our Power Query blog. This week, I continue finding a solution to a
challenge involving a choice of filters by transforming Tbl_Sales_Data.
In this series, I am considering a filtering challenge. Essentially, I have a Table of data, Tbl_Sales_Data, shown below::
data:image/s3,"s3://crabby-images/7d283/7d283dbecd1d2e757f6166427bb9257b6d2e7c40" alt=""
I will be filtering this data, by comparing values from one of these Tables, which have been named Tbl_Dates, Tbl_Amounts and Tbl_Person:
data:image/s3,"s3://crabby-images/c0f6e/c0f6e16472859d416ec19d9737b80b340a04058c" alt=""
The choice of which Table to use is controlled by a dropdown, which has been given the Named Range P_Choice and another translation Table, Tbl_Translation:
data:image/s3,"s3://crabby-images/3f716/3f71663307c6027949b7d81ef29d006cfad61ce1" alt=""
In Tbl_Translation, the first column, Choice will link to the value from the dropdown. The second column Translation, then translates to a column from the data Table. All of the data has been entered manually and the results will be driven by the value selected in P_Choice.
data:image/s3,"s3://crabby-images/bbd07/bbd07f59f135e6252e958d8acc3e564009060623" alt=""
Last week, I started with the queries I had extracted to Power Query, and combined them to build on to the P_Choice query:
data:image/s3,"s3://crabby-images/2e955/2e9553ea25d685c97d1c9dedfb6fdd93e613a82c" alt=""
The final step was to change the data type of Value to ‘Text’. The filter choices are ready; this week I move onto the Tbl_Sales_Data query and apply the filters. I begin by removing the auto-generated ‘Changed Type’ step. It is important that all the columns I am comparing have the same data type; therefore, I set them all to ‘Text’:
data:image/s3,"s3://crabby-images/13a6c/13a6c4414c8198712e6da34774f4a2bd0a617a15" alt=""
This is to prevent any mismatch errors. I choose to create a ‘Custom Column’ from the ‘Add Columns’ tab:
data:image/s3,"s3://crabby-images/8eda0/8eda01f16848b84485d9aeaf32dc05f2fd6d33dd" alt=""
I enter some M code:
data:image/s3,"s3://crabby-images/86177/8617746d732590efaa087fa767b89be8dc897686" alt=""
I have named the column Match, and the M code is:
(CheckStrings) =>
List.AnyTrue(List.Transform(P_Choice[Value], each Text.Contains((Table.Column(CheckStrings,P_Choice[Translation]{0})),_ )))
This is entering a function CheckStrings() which is using list functionality to indicate if there is a match in the column identified by Translation of P_Choice for the values in Value of P_Choice. However, this returns an error:
data:image/s3,"s3://crabby-images/c1cd2/c1cd26fc34813869dc92e3803158656082293763" alt=""
Instead of using a record from the query P_Choice:
P_Choice[Translation]{0}
I need to extract this into a parameter containing the value. I begin by taking a reference copy of P_Choice:
data:image/s3,"s3://crabby-images/045df/045df7e0af2442428fe603193014fac8ccf642a9" alt=""
I may then right-click on any cell in the Translation column and opt to ‘Drill Down’:
data:image/s3,"s3://crabby-images/282c5/282c5b4502fd027c1bab953c63005b79313905b0" alt=""
I call the new query / parameter P_Choice_Column:
data:image/s3,"s3://crabby-images/08a13/08a1347739d1d8b825c586eabae712b0ea6b3f9b" alt=""
Back in the query Tbl_Sales_Data, I amend the custom column I created:
data:image/s3,"s3://crabby-images/7a3b8/7a3b8e2fd37f611f21425bdfddab6417bffba55b" alt=""
The M code is now:
= (CheckStrings) =>
List.AnyTrue(List.Transform(P_Choice[Value], each Text.Contains((Table.Column(CheckStrings,P_Choice_Column)),_ )))
This time, the resulting column contains a Boolean:
data:image/s3,"s3://crabby-images/7eab8/7eab8d3b565ca40e98b54c48cad83e389a84810e" alt=""
I may filter to exclude the ‘FALSE’ values in Matched:
data:image/s3,"s3://crabby-images/2e661/2e661cb571e6e88eae225094feac43ff8abec2e2" alt=""
I have the data I need. It just remains for me to remove the Matched Column and use CTRL+ A whilst in any of the headings to allow me to use the ‘Detect Data Type’ option from the Transform Tab:
data:image/s3,"s3://crabby-images/5c298/5c298767830f26750bcca02accc83baaddcc00ac" alt=""
My data is ready to be loaded into the Excel workbook, where I will check that it works for all choices.
Come back next time for more ways to use Power Query!