Power Query: Heading Off – Part 7
27 March 2024
Welcome to our Power Query blog. Today, I refine the solution to 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 in part 5 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=""
Last time, I changed what happens if there is no data returned by Limit_Exceeded. I created a basic query with one [1] blank row and appended it to Limit_Exceeded.
data:image/s3,"s3://crabby-images/e3c8f/e3c8fd904c03eea5428c924444e1afd7a54aa7fa" alt=""
I deleted Column1, and loaded the results to the Excel workbook:
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 so that I don’t add a blank row if I have data. First, let’s see what happens if I change the selected Salesperson back to ‘Mary’, and refresh Limit_Exceeded:
data:image/s3,"s3://crabby-images/51258/51258f47f480f5b532bf38ee29eb873ab0f829dc" alt=""
As expected, I get two rows, as indicated by the values in the ‘Queries & Connections’ pane.
Back in my query, I look at the M code in the ‘Advanced Editor’, which I may access from the Home tab:
data:image/s3,"s3://crabby-images/be574/be57446f244e3a0000eda2c0997e0e3afb2217a7" alt=""
The last two steps pertain to the actions needed when the query doesn’t return any rows for step ‘Removed Columns’. Let’s look at that section:
#"Removed Columns" = Table.RemoveColumns(#"Filtered Rows",{"Flag"}),
#"Appended Query" = Table.Combine({#"Removed Columns", NoRows}),
#"Removed Columns1" = Table.RemoveColumns(#"Appended Query",{"Column1"})
in
#"Removed Columns1"
To make things clearer, I am going to rename step ‘Removed Columns’ to ‘Limits_Exceeded’.
Limits_Exceeded = Table.RemoveColumns(#"Filtered Rows",{"Flag"}),
Next, I determine whether there are any rows returned by step ‘Limits_Exceeded’. I am going to use the M function Table.IsEmpty(). This returns ‘TRUE’ or ‘FALSE’ for the query interrogated:
Table.IsEmpty(table as table) as logical
I will use this function to construct a condition for appending an empty row:
Check_NoRows = Table.IsEmpty(Limits_Exceeded),
I can include this to determine what the final two steps do. If there are rows, then I make them equal to Limited_Exceeded, which means that no changes are made:
Limits_Exceeded = Table.RemoveColumns(#"Filtered Rows",{"Flag"}),
Check_NoRows = Table.IsEmpty(Limits_Exceeded),
#"Appended Query" = if Check_NoRows then Table.Combine({Limits_Exceeded, NoRows}) else Limits_Exceeded,
#"Removed Columns1" = if Check_NoRows then Table.RemoveColumns(#"Appended Query",{"Column1"}) else Limits_Exceeded
in
#"Removed Columns1"
This gives me the complete query:
data:image/s3,"s3://crabby-images/9f74e/9f74e3e53a5c448f6a848e69d9ffed3ddf53c2ae" alt=""
I click Done, and check if this has the desired effect:
data:image/s3,"s3://crabby-images/24e49/24e4937e5a0086c753b87134b0c6675aaa71d1f8" alt=""
This looks fine so far; I load the query to the Excel workbook:
data:image/s3,"s3://crabby-images/21837/218379047e2c171ea038b01162e6eefe797d7077" alt=""
One row has been loaded. I change the Salesperson back to ‘Newbie’ and refresh the query:
data:image/s3,"s3://crabby-images/f9ce5/f9ce5afe7c83940a6951ebaa73671565222e579e" alt=""
I have one blank row loaded, so this works as I intended. Next time, I’ll look at an alternative way to include a blank row when needed.
Come back next time for more ways to use Power Query!