Power Query: Filtering of Choice Part 1
28 August 2024
Welcome to our Power Query blog. Today, I consider a challenge involving a choice of filters, and I begin by extracting and transforming the input data.
This week, I have a new challenge. 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=""
For example, if P_Choice is ‘Salesperson’, then Tbl_Sales_Data will be filtered to only include rows where the Sales Manager matches a value inTbl_Person. If P_Choice is ‘Date’ or ‘Amount’, then the rows must match values in Tbl_Dates or Tbl_Amounts respectively.
I will begin by extracting Tbl_Sales_Data into Power Query. I choose to do this by right-clicking anywhere in the table, and choosing to ‘Get Data from Table/Range…’:
data:image/s3,"s3://crabby-images/75d4f/75d4f880a81d7f4a95c6c03dac07328fff0d8b5b" alt=""
This brings the data into the Power Query editor:
data:image/s3,"s3://crabby-images/bce28/bce283be52ff17eaf02ced8fe582aaae963e2a8e" alt=""
I ‘Close & Load to…’ from the Home tab:
data:image/s3,"s3://crabby-images/951f7/951f7f3e61f4205e5bf3b4e5c9cee33998f9297e" alt=""
In the Excel workbook, I choose to ‘Only Create Connection’. I have no need to load the data to the workbook yet:
data:image/s3,"s3://crabby-images/c11ce/c11cebe308e9e47111174243d07fa090905312d9" alt=""
I repeat this process for the other Tables in the workbook, until I have the Named Range P_Choice left to extract using the same method:
data:image/s3,"s3://crabby-images/cdf01/cdf010407f68dea736a369887d7682d89215c84d" alt=""
When I extract the data to Power Query, the default action is to ‘Promote Headers’:
data:image/s3,"s3://crabby-images/4a883/4a883070d969be2f629c72a60a5f26c735bea483" alt=""
I select the ‘Promoted Headers’ step and right-click to ‘Delete Until End’:
data:image/s3,"s3://crabby-images/a53cd/a53cd1e8777d3ad699253bb63986ff6b3a0d8ae0" alt=""
This leaves me with the Source step. I want to keep the value as a table as I wish to merge with other data.
data:image/s3,"s3://crabby-images/aa8a2/aa8a21181dbbc4425607bd7a48b2554bcb1d7eb5" alt=""
I have all the data from ‘Sheet1’ extracted and ready to solve the challenge. Next time, I will transform P_Choice by combining more data.
Come back next time for more ways to use Power Query!