Power Query: Expendable Expand
18 January 2023
Welcome to our Power Query blog. This week, I investigate how to avoid expanding data after merging.
In Join or List Part 1, I merged queries to get all the data I needed in one table. I had two queries, Expenses and Permissions:
data:image/s3,"s3://crabby-images/67ebc/67ebc02e36845c0fbaf553744002036ae06e375b" alt=""
I merged the tables to find out who has expenses that are not allowed or that require more information. I started in Expenses, and I chose ‘Merge Queries’ from the Home tab:
data:image/s3,"s3://crabby-images/e99fa/e99fa4819f7bad1225bbc77364acf2834f198eb9" alt=""
This enabled the ‘Merge Queries’ dialog:
data:image/s3,"s3://crabby-images/07869/0786923dd6b03e1a07218b116dd212b1751ad243" alt=""
I matched the data on Expense:
data:image/s3,"s3://crabby-images/0f665/0f665545175ed6368489f97e17fa5bdebb982e30" alt=""
I used the icon in the Permissions column to extract the data from the tables:
data:image/s3,"s3://crabby-images/dfa76/dfa764bdb6168d9d8dcd6064aea54df20645f486" alt=""
I only needed the information in Column2.
data:image/s3,"s3://crabby-images/a2e8f/a2e8f9cdbe53af8e30990eef1156c4ed00069c0e" alt=""
I had the data I needed, and I renamed the column Allowed to Claim? However, did I need to expand the data in Permissions to achieve this? There is another way I could have extracted the data:
Let’s revisit. I am starting at the ‘Merged Queries’ step:
data:image/s3,"s3://crabby-images/ebf66/ebf66a28d6e883079fa729c621cf1ab15e6d8d16" alt=""
I choose to add a ‘Custom Column’ from the ‘Add Column’ tab:
data:image/s3,"s3://crabby-images/d7bc9/d7bc9aad83277efaebb9ff7420c529c217b12cca" alt=""
I call the new column Allowed to Claim?, as above:
data:image/s3,"s3://crabby-images/8c2a1/8c2a1e357b9e521fca29775f3ff24b469f12ff01" alt=""
The M code for this is:
= Table.FirstValue(Table.SelectColumns([Permissions], {"Column2"}))
This is made up of two steps. Since Permissions is a column of tables, the first step is to use Table.SelectColumns() to extract only Column2 from each table. However, Table.SelectColumns() will return a table with one value in it. In order to extract the data, I use Table.FirstValue() to get the data in the first column and row.
data:image/s3,"s3://crabby-images/e718f/e718f7f43dc4afbc8768f651559ede16c28d2581" alt=""
This merely extracts the data from the column. I could also use table functionality to create columns using conditions that compare the data in the query with the data in the table.
data:image/s3,"s3://crabby-images/6972f/6972f58529cb53bf978b9df82a002f35adf4fd35" alt=""
The M code here has been extended to:
if (Table.FirstValue(Table.SelectColumns([Permissions], {"Column2"})) = "No") then "Requires Intervention"
else null
I am creating a new column which contains ‘Requires Intervention’ if the salesperson has tried to claim a restricted item.
data:image/s3,"s3://crabby-images/70f2f/70f2fbc5b2bbb54b24d038bf9599e509554c452e" alt=""
In this case, I have avoided expanding the Permissions tables and created a column that uses a condition using the data in Permissions. I would of course need to set the data type for my new columns, but this technique can save me from extracting columns that I don’t need to include in the query.
Come back next time for more ways to use Power Query!