Power Query: Even More Fun with (Un)Pivot
25 December 2019
Welcome to our Power Query blog. This week, I look at another example of unpivoting.
John, my imaginary salesperson, has been creative with his accounts yet again.
data:image/s3,"s3://crabby-images/33b6e/33b6e04e3df399dee616309f2e136407851da73a" alt=""
This time, John has decided to use two layers of titles. This does not work well with Excel or Power Query tables, so I have some transforming to do. I’d like to see a column for months, a column for amount and a column for tips – that way it’s much easier to add future data.
I start by extracting the data into Power Query using the ‘From Table’ option on the ‘Get & Transform’ section of the ‘Data’ tab. Since there are two layers of titles, I opt not to set anything as the column headers at this point.
data:image/s3,"s3://crabby-images/06242/06242e8832d813b4cedf104fabfc7d37137310cd" alt=""
This gives me all my data in columns.
data:image/s3,"s3://crabby-images/2657d/2657d9456db244df226e01d6e693a7d4e37917d7" alt=""
As last week, I will remove the ‘Changed Type’ step. It really doesn’t have much value since I have so much transforming to do, and it refers to specific column names – I need to allow for adding extra columns for other months.
= Table.TransformColumnTypes(Source,{{"Column1", type text}, {"Column2", type any}, {"Column3", type any}, {"Column4", type any}, {"Column5", type any}, {"Column6", type any}, {"Column7", type any}, {"Column8", type any}, {"Column9", type any}})
I delete this step.
data:image/s3,"s3://crabby-images/4ee80/4ee803570ccd945a03b00e8ca0519659a14d0b59" alt=""
I need to fill across my months so that each month is attached to the ‘Tips’ title as well as the ‘Amount’. However, there is no ‘Fill Across’ that I can use. I need to transform my data so that I can fill it.
data:image/s3,"s3://crabby-images/f6471/f6471091bae0715a2e4ca3b53859ad04ed4c8ef4" alt=""
On the ‘Transform’ tab, I have the option to ‘Transpose’ which will swap rows for columns. I use this.
data:image/s3,"s3://crabby-images/c2b40/c2b40f3cf623424db4b36f25bea9a021c6a30a85" alt=""
I can now right click on Column1 and ‘Fill Down’.
data:image/s3,"s3://crabby-images/493c0/493c0c6c1643d99003bc49c96a1d3ecdd0ddb472" alt=""
I want to create one column which contains all my heading information, so I choose to transform my data by merging Column1 and Column2.
data:image/s3,"s3://crabby-images/b6941/b6941f27b97dd23272812dc77f12b006193522b6" alt=""
I choose to use a space to separate my headings, but as long as I pick a separator, it doesn’t really matter what I use as long as it isn’t in either of the headings. I can remove the separator when I split the data later.
data:image/s3,"s3://crabby-images/75021/7502106f5dc553458779e7b867d8ccbe144a1b6e" alt=""
I transpose my data so that the headings are at the top.
data:image/s3,"s3://crabby-images/e4085/e4085e255dc47259d5ce10029315f7ef2d99b232" alt=""
I can now ‘Use First Row as Headers’.
data:image/s3,"s3://crabby-images/05e92/05e927c38b29a657e8bbff9616fb8ce6d6d23b1d" alt=""
The data is now in the same format as last week’s example. However, Power Query has added a ‘Changed Type’ step again:
= Table.TransformColumnTypes(#"Promoted Headers",{{" 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}})
This references the months, so I need to remove this step.
As I did last week, I need to avoiding referencing month names in the columns. To do this, I select the Expense Type column, and opt to unpivot the other columns.
data:image/s3,"s3://crabby-images/c5c92/c5c92c491ff8234197626854deb7167786fe61cf" alt=""
The M code generated is:
= Table.UnpivotOtherColumns(#"Promoted Headers", {" Expense Type"}, "Attribute", "Value")
This is good because there is no mention of the month columns. The months, amounts and tips 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/91455/91455605b129bdd8c3b2c298ec3b4acfb623b078" alt=""
I opt to use ‘Split Columns’ on the ‘Transform’ tab, and choose ‘By Delimiter’
data:image/s3,"s3://crabby-images/537b3/537b368aea8f25c3834ffc0543d87588ad31255c" alt=""
I choose to split at ‘Space’, since this is the delimiter I introduced earlier.
data:image/s3,"s3://crabby-images/d28b8/d28b8b6c69f0bcd11159389a89de1631cde5295b" 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/4e94c/4e94ce7519f446f091cbb7ccf3a6939518623c52" 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/ca3bf/ca3bfcac6c647eee85398e24c6dc1cb2877cae63" alt=""
Finally, I choose to order by month (just like last time), 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/e20fa/e20fa967d038dcbd5e3da56ed706fa9e84035c51" alt=""
I create this column and sort by it.
data:image/s3,"s3://crabby-images/b3cad/b3cad13464b3b9f15936b1471b1ef73aed018fa1" alt=""
I can now delete the Month Number column.
data:image/s3,"s3://crabby-images/d53fd/d53fda8cef366582d23d3d4c2f90437849dcc6c9" alt=""
My data is now ready to append and update if further months are added.
Come back next time for more ways to use Power Query!