Power Query: Heading Off – Part 6
20 March 2024
Welcome to our Power Query blog. Today, I look at how to solve 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/71509/7150950273bde5cc5d5d5a5f3d7e10532ab60fda" alt=""
In Part 1, I created two [2] queries, and grouped Expenses.
data:image/s3,"s3://crabby-images/13fd7/13fd7a94d159f670ae955abb6a19896c3f48fae1" 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/554ae/554ae8111f67ea0379d78965d12dbc3712f432de" alt=""
In Part 3, I loaded Limit_Exceeded to a new worksheet.
data:image/s3,"s3://crabby-images/473b1/473b1555c0e451cc6df5ae9277b41d0bb35b57c2" alt=""
I removed the header row and changed some of the data in Expenses.
data:image/s3,"s3://crabby-images/b6fd4/b6fd4587b0240d64a633a067e7098586e5edcf5d" alt=""
In Part 4, I ran the query for a single salesperson.
data:image/s3,"s3://crabby-images/c9881/c98813a69224a4af816405ab99fcc0000c77f6d3" alt=""
I extracted this cell and created a parameter P_Salesperson:
data:image/s3,"s3://crabby-images/d5447/d5447dafc12aca7caa7c5325e7429e6e1d23b8de" alt=""
I used this parameter to limit the data in Expenses:
data:image/s3,"s3://crabby-images/dd24e/dd24ef0e78ed78a0a13f5ee9f73c24e5af03e96c" alt=""
When I refreshed Limit_Exceeded, I checked the results:
data:image/s3,"s3://crabby-images/20530/20530db04331e1d02650d6a853e1408b250f642f" alt=""
The results correctly showed one row of data and no headings. However, things changed last time when I selected a different Salesperson:
data:image/s3,"s3://crabby-images/bc170/bc1707e0e19be1035260ebd442604df8e8c25925" alt=""
When I refreshed Limit_Exceeded, it had moved the data from the previous selection into the header row.
data:image/s3,"s3://crabby-images/ab488/ab48827d50835433c277209c7871b8bba48972b6" alt=""
When I deleted the top row from the Excel sheet, things got worse!
data:image/s3,"s3://crabby-images/ee974/ee9741e4ba48c489f8ffda436720a2643522f2ed" alt=""
Since the problem is being caused by writing an empty query to a Table with no headers, I need to change what happens if there is no data returned by Limit_Exceeded.
data:image/s3,"s3://crabby-images/fb152/fb1527d481a61c457e513c19a52ba3807a70bf4d" alt=""
I could add a row if my table is empty. One way to do this, it to create a helper query that I can append to my existing query. I don’t need to include all the columns; one will be enough. I create a new blank query:
data:image/s3,"s3://crabby-images/22751/22751db55e912a860a538a398ec9c72e16b320e5" alt=""
This is going to be a very simple query!
data:image/s3,"s3://crabby-images/0ab95/0ab95aca4ebecbc1d5cfe609ef0f166afcd2bd62" alt=""
I have created a list of one blank row by using the M code:
= {“ ”}
I need to convert the list to a table so that I may append it. I use the ‘To Table’ option on the ‘List Tools’ Transform tab:
data:image/s3,"s3://crabby-images/007da/007da59a3aed43baf042d62cca6ed2d842f25b8f" alt=""
I take the defaults and create the table:
data:image/s3,"s3://crabby-images/cd8a3/cd8a35fc9eec8ac699e0ccf7cc4571e975554b79" alt=""
I go back to Limit_Exceeded, and choose to ‘Append Queries’ from the Home tab.
data:image/s3,"s3://crabby-images/f3b98/f3b98bf922d73a18ddbbaa86a5ca4a93429a6cc3" alt=""
I select NoRows, and click OK:
data:image/s3,"s3://crabby-images/e3c8f/e3c8fd904c03eea5428c924444e1afd7a54aa7fa" alt=""
I delete Column1, and ‘Close & Load To…’ from the Home tab (as I do not want to load NoRows to the workbook). Having set NoRows to ‘Connection Only’, I view the results:
data:image/s3,"s3://crabby-images/d7824/d78245384f97eb09fa42e39d4b434bfbd63119ef" alt=""
This is looking much better! Clearly, it’s not ideal to have a blank row, but it is better than showing the wrong data. I’ll refine this approach next time so that I don’t add a blank row if I have data.
Come back next time for more ways to use Power Query!