Power Query: More Fun with (Un)Pivot
18 December 2019
Welcome to our Power Query blog. This week, I look at another use for unpivoting.
John, my imaginary salesperson, has been creative with his accounts again.
data:image/s3,"s3://crabby-images/0e048/0e0483b09d44f87f024fcae93407b6fb63cf0838" alt=""
In this case, I’d like to see a column for months, a column for amounts, a column for expense category and for tips – that way, it’s much easier to add future data, as additional categories can be readily added.
I start by extracting the data into Power Query using the ‘From Table’ option on the ‘Get & Transform’ section of the ‘Data’ tab.
data:image/s3,"s3://crabby-images/455da/455dabc09b5389ff644d61945d290a757134cc85" alt=""
As with last week’s blog, I need to remove the ‘Changed Type’ step because it refers to specific month columns:
= Table.TransformColumnTypes(Source,{{"Expense Type", type text}, {"August Amount", Int64.Type}, {"August Tips", Int64.Type}, {"September Amount", Int64.Type}, {"September Tips", Int64.Type}, {"October Amount", Int64.Type}, {"October Tips", Int64.Type}, {"November Amount", Int64.Type}, {"November Tips", Int64.Type}})
I delete this step.
data:image/s3,"s3://crabby-images/02cdd/02cdde7552f4e95fe3a20debb94de3a11563ab0d" alt=""
I need to avoiding referencing month names in the columns; to achieve this, I select the Expense Type column, and opt to unpivot the other columns.
data:image/s3,"s3://crabby-images/547e9/547e9ffbd2f865db26779cf50a0e26c6c610027c" alt=""
The M code generated is:
= Table.UnpivotOtherColumns(Source, {"Expense Type"}, "Attribute", "Value")
This is good because there is no mention of the month columns. The months, amounts and tip titles now appear as data under the Attribute column. I need to perform further transformations to sort out this column. I begin by splitting the Attribute column into the separate titles.
data:image/s3,"s3://crabby-images/9a88c/9a88c9e3e3869b6430d0b840c1b3a338b09ee786" alt=""
I opt to use ‘Split Columns’ on the ‘Transform’ tab, and choose ‘By Delimiter’.
data:image/s3,"s3://crabby-images/d8c0c/d8c0c0a680055571fea541990731439da047d958" alt=""
I choose to split at ‘Space’.
data:image/s3,"s3://crabby-images/e818d/e818d446e91b6b7a1bc88f985b6a5004eb5de40a" alt=""
I can rename Attribute.1 to Month. Attibute.2 contains my two other column headings, so I need to pivot this column by selecting it and using the ‘Pivot’ option on the ‘Transform’ menu.
data:image/s3,"s3://crabby-images/8eef8/8eef819ea95b1e0613408351766ea0158b506207" alt=""
I need to choose what to put in my new columns; they should contain the associated Value, since that contains the amount.
data:image/s3,"s3://crabby-images/e4147/e414771fb89736db9d91ccab5fbcd8e897e04859" alt=""
Finally, I choose to order by month, since that makes the data easier to read. I need to create a temporary column with month number in order to do this, as I don’t want the months in alphabetical order!
data:image/s3,"s3://crabby-images/1f1c2/1f1c2efc2d5e5b8d219b751366a36456c5f51da3" alt=""
I create this column and sort by it.
data:image/s3,"s3://crabby-images/cd519/cd5194a93de994189dd92175ffb8a31dbe8d4284" alt=""
I can now delete the Month Number column.
data:image/s3,"s3://crabby-images/c6d24/c6d242fd11e60d5bd98b8e750b6952781f57857e" alt=""
My data is now ready to append and update if further months are added. Next time, I will look at another example of unpivoting.
Come back next time for more ways to use Power Query!