Power Query: Heading Off – Part 4
6 March 2024
Welcome to our Power Query blog. Today, I continue to consider an issue that occurs when I load to a Table with no headers.
I plan to show a particular issue with Power Query and Tables without headers. However, first I need to create the scenario, and I will show a few methods and tips along the way. I have two Tables of data:
- contains my salespeople’s expenses (Expenses)
- determines the expenses that will be covered by each supplier (Supplier_Limit).
data:image/s3,"s3://crabby-images/8cd85/8cd85a81c0ffbddff4fa3ec56835951650ce08e1" alt=""
In Part 1, I created two [2] queries, and grouped Expenses.
data:image/s3,"s3://crabby-images/57f1e/57f1e4bb438d366737ec63a0319ab4e4ce76c89f" alt=""
In Part 2, I merged Expenses with the Supplier_Limit query to create Limit_Exceeded, which tells me if any limits have been breached.
data:image/s3,"s3://crabby-images/bc63f/bc63f0bd725822bfce3d882cfe95998e0285cd5d" alt=""
Last time, I loaded Limit_Exceeded to a new worksheet.
data:image/s3,"s3://crabby-images/82d6e/82d6eacea6d8e32567b5538c15920b22c9034cee" alt=""
I removed the header row and changed some of the data in Expenses.
data:image/s3,"s3://crabby-images/93cd1/93cd1eac19640cc15b6f9ce4ba4744d263430480" alt=""
This time, I will see what happens when the requirements change, and I run the query for a single salesperson. On the ‘Expenses’ sheet, cell N2 contains the salesperson value I want to use. This cell may be identified by the name P_Salesperson:
data:image/s3,"s3://crabby-images/ff1f3/ff1f3803e9905dd1a29f3bff9468676d72cdf436" alt=""
If I right-click on cell N2, I have the option to ‘Get Data from Table/Range’.
data:image/s3,"s3://crabby-images/b3374/b3374a08b18ad7d33ca28928712d5ec440a2bfe2" alt=""
This creates a new query called P_Salesperson:
data:image/s3,"s3://crabby-images/cfdb5/cfdb5d22f6e8f253c4deefc957b83720762298fd" alt=""
Note that Power Query has decided to promote headers, leaving an empty table! The ‘Changed Type’ step is also ineffective since there is no data to work with. I only need the Source step, so I delete the other steps:
data:image/s3,"s3://crabby-images/1562f/1562f8bacf41dc9518f7c81e80ff16cdecf62827" alt=""
I click in the cell and right-click to ‘Drill down’:
data:image/s3,"s3://crabby-images/8e555/8e5556553a84146f1e68d94b266f7db7af5e2f40" alt=""
This gives me the parameter I need.
data:image/s3,"s3://crabby-images/55270/55270ade11a2c4ec24abe4a0d6e5a0b3d507b788" alt=""
Since I will be reducing the data, I should apply the parameter as close to the source as possible (ignoring the option of doing this in Excel as this is a Power Query blog!). In the Expenses query, I go to the Source step:
data:image/s3,"s3://crabby-images/eab51/eab51a07d5311747e90d9a717c417e4fc3aa952e" alt=""
I may add a filter on Salesperson:
data:image/s3,"s3://crabby-images/d8220/d8220efe3e027b4e00d98f51515b2792cf508a16" alt=""
I choose ‘Mary’ as my placeholder value. I will change this to P_Salesperson later. When I click OK, I received a warning:
data:image/s3,"s3://crabby-images/276c1/276c12d6616f31b48ee7bba848cb6d1bed0595b2" alt=""
I may ignore the warning and click Insert, as I am happy to insert a step.
data:image/s3,"s3://crabby-images/37d06/37d064ef838a7ddcf19daf2de4e99c44fe55d880" alt=""
The M code for the ‘Filtered Rows’ step is:
= Table.SelectRows(Source, each ([Salesperson] = "Mary"))
To use the parameter, I change this to:
= Table.SelectRows(Source, each ([Salesperson] = P_Salesperson))
This gives me the same results:
data:image/s3,"s3://crabby-images/e926b/e926bbfed534914442b5449867f7a46c0cd1f77e" alt=""
My final query now looks like this:
data:image/s3,"s3://crabby-images/08f44/08f44f6af4c698e17b05163d49c4a9718fe6b3e4" alt=""
Now I have reduced the data in Expenses, I check the Limit_Exceeded query.
data:image/s3,"s3://crabby-images/c4c54/c4c54254068dfe878b6d7f734c5760a7ff23c685" alt=""
I now only have one [1] row. I ‘Close & Load To…’ as I did last week, so that my parameter query can be set to ‘Connection Only’:
data:image/s3,"s3://crabby-images/28526/28526fc81761c20ffe2fa22e1e2ec47af678afac" alt=""
I refresh Limit_Exceeded and look at the results:
data:image/s3,"s3://crabby-images/bdae3/bdae3700c2f2bec20b5db004964eda07ec0a2f1d" alt=""
The results correctly show one row of data and no headings. However, things change when I select a different Salesperson:
data:image/s3,"s3://crabby-images/af679/af67981e6aba2a3072d2ad224b8be250435e3c33" alt=""
More on this next time!
Come back next time for more ways to use Power Query!