Power Query: Dynamic Merging
6 May 2020
Welcome to our Power Query blog. This week, I look at working dynamically with merged queries.
I have some data from my imaginary salespeople, which I have loaded into Power Query and merged.
data:image/s3,"s3://crabby-images/47f1e/47f1edca4d7e598f718e164b86002b2ed0674104" alt=""
I expand the icon next to Tent Packs.
data:image/s3,"s3://crabby-images/f00d0/f00d0731e57eac452e3354d1847750dfa8dc5d94" alt=""
I select the two columns I want, and then continue.
data:image/s3,"s3://crabby-images/8bcb2/8bcb28f27a0e99f9fd52a1e9be23bc14c034193b" alt=""
The problem is, the M code created for this step is:
= Table.ExpandTableColumn(Source, “Tent Packs”, {“Item”, “Cost”}, {“Item”, “Cost”})
which specifically mentions the column names Item and Cost, meaning that if I add more columns to Tent Packs they will not be expanded. I can add a new column, Supplier, to show this.
data:image/s3,"s3://crabby-images/95bd6/95bd6f9aa1cb509b6426368a65c1a1b44ac0fe7f" alt=""
However, when I look at my merged query:
data:image/s3,"s3://crabby-images/99a7d/99a7d3ab2a703b407dd964da89129a2680881beb" alt=""
Since the expand step specifies column names, the new column is not included. I need another way to create this step so that it can be dynamic. My current step is:
= Table.ExpandTableColumn(Source, "Tent Packs", {"Item", "Cost"}, {"Item", "Cost"})
The last two parameters are lists of column names: {"Item", "Cost"} and {"Item", "Cost"}. Instead of this, I can get the column names from the table Tent Packs:
=Table.ExpandTableColumn(Source, "Tent Packs", Table.ColumnNames(#"Tent Packs"))
data:image/s3,"s3://crabby-images/283a8/283a8458a948b369413ea9718fb5e6032c45b2a9" alt=""
This time I have all three of my columns. In my case, the linked column in Tent Sales has a different name to its corresponding column in Tent Packs, i.e. Tent Pack links to Pack Number. If they had the same name, then I can avoid extracting Pack Number by removing it from the list of columns.
=Table.ExpandTableColumn(Source, "Tent Packs", Table.ColumnNames(#"Tent Packs"))
This would change to:
= Table.ExpandTableColumn(Source, "Tent Packs", List.RemoveItems(Table.ColumnNames(#"Tent Packs"), {"Pack Number"}))
data:image/s3,"s3://crabby-images/1c120/1c12066e792cb6e6d8605b3dd7f7c985ea48dabf" alt=""
I can then add steps to this query knowing that all columns from Tent Packs will be expanded.
Come back next time for more ways to use Power Query!