Power Query: Filtering of Choice Part 2
4 September 2024
Welcome to our Power Query blog. This week, I continue to work on a challenge involving a choice of filters by transforming P_Choice.
Last week, I described my current 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=""
Having extracted all the Tables and P_Choice to Power Query, I need to consider how I should begin to transform my data.
The key to solving this problem lies with lists. I need to convert the queries Tbl_Dates, Tbl_Amounts and Tbl_Person into a format where I have a list of values within the table and an identifier for the list, which will allow me to merge with P_Choice.
I begin in Tbl_Dates, where I remove the ‘Changed Type’ step, and choose to ‘Unpivot Columns’ from the right-click menu:
data:image/s3,"s3://crabby-images/4eb47/4eb47553c0ab1c428534e29207f5c86c08f60874" alt=""
This gives me two [2] columns, the list of values and the identifier, as required:
data:image/s3,"s3://crabby-images/6a810/6a81008f79f29dce10cd893cb11cef78feff50dd" alt=""
I repeat this process for Tbl_Amounts:
data:image/s3,"s3://crabby-images/cfab7/cfab7e767bdf257a007333af418691d4012d63dc" alt=""
I repeat the process one more time for Tbl_Person:
data:image/s3,"s3://crabby-images/a4581/a458125edd8e34b1bb9d8b5bceb23238683f7536" alt=""
I am ready to start building from P_Choice. Starting from here, I need to merge with all three [3] of the unpivoted queries: Tbl_Dates, Tbl_Amounts and Tbl_Person, as I may need to get the data to filter by from any of these tables, depending upon the value in P_Choice. Unlike appending, I may only merge with one other table at a time. However, the data in the three unpivoted tables is in the same structure, therefore I may append them, and then merge the result with P_Choice.
I begin in Tbl_Dates, and choose to ‘Append Queries’ from the Home tab:
data:image/s3,"s3://crabby-images/c6ecb/c6ecb7ee15d6f812beec4b42ba6461253e6a8af5" alt=""
In the dialog, I choose to append ‘Three or more tables’, and whilst holding down the CTRL key, I select Tbl_Amounts and Tbl_Person from ‘Available tables’. I may then use the ‘Add’ button to create a list of ‘Tables to append’:
data:image/s3,"s3://crabby-images/72f44/72f44f9323b1a700070300be14efbddc3cfb7395" alt=""
I click ‘OK’ to perform the append:
data:image/s3,"s3://crabby-images/5b638/5b638a71e55e09c938e2910c6a5521456e8b0b4f" alt=""
I have renamed the step to reflect the tables appended. I return to P_Choice, where I select ‘Merge Queries’ from the Home tab:
data:image/s3,"s3://crabby-images/ea62d/ea62d53014aeacbe3e0770aa6626a91714a8d300" alt=""
I choose to merge with Tbl_Dates:
data:image/s3,"s3://crabby-images/37be3/37be368bdc56dddff08e975a3fbd37e3bfcbb142" alt=""
I link Column1 from P_Choice to Attribute of Tbl_Dates and use the default ‘Left Outer’ join. The message that ‘The selection matches 1 of 1 rows from the first table’ indicates that at least one filter value has been selected:
data:image/s3,"s3://crabby-images/78883/78883caa7fc4147ee2d3b70920f8a4f11394d7f8" alt=""
I may now expand the data to find the filter values:
data:image/s3,"s3://crabby-images/f1cf6/f1cf607d09b7f4f77c558d1250290b0a39423d98" alt=""
I only need the Value column, and I have no need to ‘Use original column name as prefix’:
data:image/s3,"s3://crabby-images/ca5b6/ca5b66f7e3f8cfe57683077ba7851c894a46b087" alt=""
The data is still not quite ready. I need to merge with Tbl_Translation, as I will need to know the column name on Tbl_Sales_Data.
data:image/s3,"s3://crabby-images/42ea8/42ea81624c6f4e2b4d8e3638bf9d4900b78a8d33" alt=""
I link Column1 of P_Choice to Choice of Tbl_Translation and use the default ‘Left Outer’ join again.
data:image/s3,"s3://crabby-images/f077a/f077a9a9bf5c52e4ee14a092fc0977e965746c82" alt=""
I rename the step to make it clear that I have picked up the translations. I may now expand the data:
data:image/s3,"s3://crabby-images/1062e/1062e96b5717062b6885d13056276bf72afe8b52" alt=""
Having selected the Translation column, I may now remove Column1 too:
data:image/s3,"s3://crabby-images/38360/38360373122142eede120660fd6093ad54b6764a" alt=""
Finally, I change the data type of Value to ‘Text’. The filter choices are ready; next time I will turn my attention to the Tbl_Sales_Data query.
Come back next time for more ways to use Power Query!