Power Query: Three Sheets to the Table
9 June 2021
Welcome to our Power Query blog. This week, I look at combining sheets where the columns do not match.
I have some data that has come in from John, one of my imaginary salespeople. He has sent in some sales data, and I need to pull it into one table. The data is spread over three sheets, which are all in a similar format:
data:image/s3,"s3://crabby-images/2e8e7/2e8e74bc520c59587d342c8e1d9ae0d947807d58" alt=""
data:image/s3,"s3://crabby-images/ac637/ac637fd838bbc47686358d5c984546fbae9ebac0" alt=""
In my (new) Excel workbook, I go to the Data tab and choose to ‘Get Data’ and then ‘From Workbook’, viz.
data:image/s3,"s3://crabby-images/f09ff/f09ff5bab41b2b0f12b6843d9cc054dfe527fb4c" alt=""
This allows me to see the data in John’s workbook:
data:image/s3,"s3://crabby-images/01d1b/01d1bfb9fe8fb164bc05d9224b2450dd3c7327e4" alt=""
Because the columns are not the same for each sheet, if I tried to append my sheets, I would end up with the dates in the middle of my data, which is not what I want. I need to transform each sheet before I combine them. However, there is another option I can take if I right-click on the workbook:
data:image/s3,"s3://crabby-images/1dab0/1dab0c7ec4e88cbaee96b5a72189978176d7bb98" alt=""
I can transform the data in the workbook. I select this option.
data:image/s3,"s3://crabby-images/cc285/cc285d637739b4e218a876aa3a2178d0f67739f6" alt=""
This gives me the source step (I know I could have chosen sheets and deleted steps to get to this point, but this is neater!). I make sure that I am only including those sheets I want to combine.
Next, I create a duplicate query: I am going to work out what I will do with one of my sheets.
data:image/s3,"s3://crabby-images/6abf1/6abf1c9b7e594705e8a03615d3f8e41d93769a34" alt=""
I call my new query Process_Sheet.
data:image/s3,"s3://crabby-images/fb1f4/fb1f4d6b7059dd09b7ff09ca9b8169d78fdd4f48" alt=""
I filter to keep Sheet1, and select the Data column, which I right-click in order to remove the other columns. I can then expand it to see my data.
data:image/s3,"s3://crabby-images/fa52c/fa52c638aaaf70a018b8e5f05903591fda72fcd6" alt=""
I don’t need a prefix.
data:image/s3,"s3://crabby-images/50845/50845be2d16eecd68eee21fc768635dec9c80b30" alt=""
If I am going to append my data, I need the dates to be in a column. First, I promote my headers, which I can do in the Transform tab by ‘Using First Row as Headers’. If a ‘Change Type’ step is created, I must delete it, so that the column names are not referenced (as they will be different for the other sheets).
data:image/s3,"s3://crabby-images/43d4f/43d4f3f4bc935934cbde28db295a53b5466e89bc" alt=""
I can then select the Tent Type column and unpivot everything else.
data:image/s3,"s3://crabby-images/4c4a1/4c4a1cd165e4d565314e9a54995df9b87ecd4af9" alt=""
This looks good; I can now move onto the next step. This query is going to be a function, but first I need to set up a parameter, which will indicate which sheet is being processed. I can manage parameters on the Home tab.
data:image/s3,"s3://crabby-images/232fb/232fb74b295eb039494a477f70992130db700cdf" alt=""
I create a new parameter, Sheet.
Sheet must be text, and it will be required by my new function. To begin with, Sheet will have a value of ‘Sheet1’.
data:image/s3,"s3://crabby-images/dc6dc/dc6dc1eb58a329eb2b3cd4565cb485eb9cea46b4" alt=""
Back in my Process_Sheet query, I go back to the ‘Filtered Rows’ step where I selected ‘Sheet1’. I am going to use the parameter instead.
data:image/s3,"s3://crabby-images/059bb/059bb110147a7953c158e20072b29607d28e26df" alt=""
I choose my new parameter and click ‘OK’.
data:image/s3,"s3://crabby-images/e0a58/e0a581bd0f1d7c89e8666a51dc51dff534b23960" alt=""
Because the default value is ‘Sheet1’, the parameter works in the same way as before. Now I need to make this query into a function.
data:image/s3,"s3://crabby-images/a8bd3/a8bd30335a5c1c8fe7e49f19a1a7d1128c2d9d08" alt=""
I am prompted for a function name, which I call fx_Process_Sheet.
data:image/s3,"s3://crabby-images/5fda7/5fda7a2dadcd9e75ba98f00471ec6067bba5f179" alt=""
My function is ready to use.
data:image/s3,"s3://crabby-images/7ef51/7ef51159dfd28054b701305e1121d65df41f49df" alt=""
Back in my original query, I want to invoke my function. In the ‘Add Column’ tab, I can ‘Invoke Custom Function’ and pass in the sheet name.
data:image/s3,"s3://crabby-images/0efac/0efacf8f606d36b9477d324474321ceda40f94d5" alt=""
Clicking ‘OK’ gives me a new column. This should hold all the data I need.
data:image/s3,"s3://crabby-images/84aca/84acade6b9652dc975b8d04324db80f634ddae90" alt=""
I can now expand it.
data:image/s3,"s3://crabby-images/d172e/d172e91130d0bdd6e958c1cd2dcaca9bc53ead58" alt=""
I select all columns and click ‘OK’.
data:image/s3,"s3://crabby-images/e96a2/e96a2b4246260ab64ebe5ab54de0efe43f746b9f" alt=""
I have my data, I just need to change the data types on the Transform tab, rearrange it, and rename my columns.
data:image/s3,"s3://crabby-images/0841f/0841f87837f672cddf74de8923799382c5e40588" alt=""
Come back next time for more ways to use Power Query!