Power Query: Picky Pivoting
23 September 2020
Welcome to our Power Query blog. This week, I look at unpivoting data with multiple headings.
I have some tent data:
data:image/s3,"s3://crabby-images/9abc1/9abc118290a5ea35556c8c6aa88bbbdc49cccd65" alt=""
I want to get this data into a standard table format so that I can analyse it and combine it with other data. I want to do this in a dynamic way, so that if more months are added to my Excel sheet, then the data will be transformed correctly.
I start by extracting the data to Power Query by selecting ‘From Table’ in the ‘Get & Transform’ section of the Data tab.
data:image/s3,"s3://crabby-images/f0c62/f0c629f8828a84c95bd62506d33e77bd3a439048" alt=""
Power Query automatically selects my data without the ‘Grand Total’ line, and this is fine for my purposes. I choose not to select the ‘My table has headers’ box as it wouldn’t find the correct headers in any case.
data:image/s3,"s3://crabby-images/9c41f/9c41f448b97f3c3d7946a05c85ef5bf9fa96a280" alt=""
I start by sorting out my supplier data, so I right click on Column1 and choose to ‘Fill Down’.
data:image/s3,"s3://crabby-images/98abc/98abc817cd67c3a89bf624269b964bf367938a8b" alt=""
I know that I want to keep the supplier data and the tent type data, so I choose to combine these columns. The remaining columns will need more manipulation to sort out the headings.
data:image/s3,"s3://crabby-images/ad756/ad7567a4e9b0aee9218ce4c77d7d4985047f3c89" alt=""
On the Transform tab, I can select Column1 and Column2 and choose to ‘Merge Columns’.
data:image/s3,"s3://crabby-images/9b48c/9b48c6766140914db49f9c4195b00034e9a4c2fc" alt=""
I choose to separate my data by a colon (:), and use a meaningful name for my column name.
data:image/s3,"s3://crabby-images/df7ed/df7edf127ac7e9298d695a89a1b376016c7e8ea0" alt=""
On the Transform tab, I also have the option to ‘Transpose’ my data, which will treat columns as rows and rows as columns.
data:image/s3,"s3://crabby-images/8e892/8e892cce7ca7dd1b85f6b1d2756379164dc647a2" alt=""
When I click ‘Transpose’, my data is swapped around:
data:image/s3,"s3://crabby-images/37a4a/37a4a918576c942cb6614b3886886965d9393a56" alt=""
Next, I need to fill down the data in my first column so that ‘Rented’ or ‘Sold’ appears next to each month.
data:image/s3,"s3://crabby-images/935ba/935ba0579d1619b14b05acdacc160bc452c5c92d" alt=""
Now, I can promote the row with the supplier and tent type information to be my headers from the ‘Use First Row as Headers’ section.
data:image/s3,"s3://crabby-images/9bec9/9bec978450b122ee6c027ea216251a576950e173" alt=""
The data is already looking much better. I am ready to unpivot the quantities. I select the first column (Rented / Sold), and the Supplier:Tent Type column and choose to unpivot the other columns. I can do this by right clicking with my columns selected.
data:image/s3,"s3://crabby-images/24f2e/24f2ea3837648d9a7d6fcfa6ed000714ec9bf7fb" alt=""
I can now split the Attribute column into my original columns.
data:image/s3,"s3://crabby-images/8006c/8006c43b0654f1ef5f3e3bef264e9719d95e798b" alt=""
I choose to split by colon.
data:image/s3,"s3://crabby-images/74ce4/74ce426a3c81035484d48b30d86fac295e76d8ca" alt=""
I can now rename my columns.
data:image/s3,"s3://crabby-images/a8204/a8204ba35b1d167cef33c5c93ef1c1dc6bb73405" alt=""
I remove my total rows by filtering on Supplier, looking for the word ‘Total’.
data:image/s3,"s3://crabby-images/76d18/76d18d6c95c567c0779a4dc975e14556cb0c3231" alt=""
I choose ‘Does Not End With…’ just to reduce my chances of coinciding with an actual supplier name.
data:image/s3,"s3://crabby-images/021c2/021c2411adf9ae8246822424647dd6fb67eb6cec" alt=""
I click ‘OK’ to see my data.
data:image/s3,"s3://crabby-images/9a530/9a530a4acb131073054e9c73a7cda336484074d7" alt=""
I reorder the columns.
data:image/s3,"s3://crabby-images/39c20/39c2056dd20241910d2060fbb861663246aafb9a" alt=""
I can now use ‘Close & Load’ on the ‘Home’ tab to upload my data to Excel.
data:image/s3,"s3://crabby-images/d75cb/d75cbee808cfe1f9cb48e1b705b3ed7083ee85aa" alt=""
Finally, I need to add data for July to my original Excel spreadsheet to check my query still works.
data:image/s3,"s3://crabby-images/fe553/fe553ef2f1a9b9dcc918e5e5f0e01b3452bdd3a0" alt=""
I refresh my query and check the data.
data:image/s3,"s3://crabby-images/334c1/334c14249f8c865a7d7207893945b2330aa93c85" alt=""
The data for July has been included.
Come back next time for more ways to use Power Query!