Power Query: Next (Row) Again Please
19 February 2020
Welcome to our Power Query blog. This week, I look at another solution to last week’s problem referencing other rows.
John, my reliable imaginary salesperson, has been filling in data again. Referring to last week’s blog, I have some information on items purchased by customers in December:
data:image/s3,"s3://crabby-images/84c4a/84c4afe8eb805b5cd46fbe79753d3ffbbc79845d" alt=""
He has decided to combine the item and the description in the same column, so I need to move the description into a separate column and remove the extra rows.
This week, I look at a solution, where I use a duplicate query.
I extract my data to Power Query using the ‘From Table’ option on the ‘Get & Transform’ section on the ‘Data’ tab.
data:image/s3,"s3://crabby-images/e0237/e02371096c3b3ffe91cf06356d194603bb99dc4c" alt=""
My data has headers, so I accept the defaults.
data:image/s3,"s3://crabby-images/da58a/da58aab28544dd6c845e23ab4af8804e70b2d942" alt=""
I can open the ‘Queries’ pane to the left of the screenshot.
data:image/s3,"s3://crabby-images/8023c/8023c083baf956f4efd7c245f49bcc4f7c547217" alt=""
I right click on my query to see the options available: I choose the ‘Duplicate’ option.
data:image/s3,"s3://crabby-images/288a2/288a2ac87831dbd0886879d50510cee10eeb72cd" alt=""
I have a query ‘Table1 (3)’ that is the duplicate of my original query ‘Table1 (2)’. I go back to ‘Table1 (2)’, and choose to create an index from the ‘Add Column’ tab.
data:image/s3,"s3://crabby-images/945d3/945d31b1ebc2366fea1dad2dffed4494eacdefb4" alt=""
I choose to start my index ‘From 1’.
data:image/s3,"s3://crabby-images/57155/57155b2bfb491604a1062bdfa02614a67628db4f" alt=""
I create an index on my duplicate query, but this time I start from zero (0).
data:image/s3,"s3://crabby-images/d987b/d987b60a66f3f7a499881b30c3e79ac90b97a501" alt=""
I choose to ‘Merge Queries as New’ from the ‘Merge Queries’ section on the ‘Home’ tab.
data:image/s3,"s3://crabby-images/b0864/b0864a06a3544c8dde268f877cfa12c0f0c0a9e8" alt=""
I select to merge my queries on Index.
data:image/s3,"s3://crabby-images/5c48a/5c48a56ee3537f84c5d0dac81e89e18822b074fc" alt=""
I take the default join, ‘Left Outer’, which will take all of the data from ‘Table 1 (2)’ and combine (merge) it with matching data from ‘Table 1 (3)’.
data:image/s3,"s3://crabby-images/018bc/018bca7a61b43258b92b8df65d1849457e5ea262" alt=""
I have my original table ‘Table1 (2)’ with a new column, which contains the linked rows from ‘Table1 (3)’. I expand the data from ‘Table1 (3)’ by clicking the icon next to the column name.
data:image/s3,"s3://crabby-images/b3e8c/b3e8c3f5f7fd4f0460e4afb58a21c488a3c9a90b" alt=""
I do not want to ‘Use original column name as prefix’.
data:image/s3,"s3://crabby-images/a8509/a8509b27b13df6c439d9aae822283e5637869594" alt=""
I filter Customer to remove the null values.
data:image/s3,"s3://crabby-images/f55f4/f55f4ed16944c23aed0ff558eea8af003b388952" alt=""
This gives me rows that have the item code in Item Code/Description and the description in Item Code/Description.1.
data:image/s3,"s3://crabby-images/f6885/f688581322d21d31b2c1097488fe1a44fa1a6360" alt=""
I can now rename Item Code/Description and Item Code/Description.1 to Item Code and Description respectively. I also remove the other columns that I no longer need, including the indices.
data:image/s3,"s3://crabby-images/e2364/e2364303774314093c69c8891254b3d89066e577" alt=""
I close and load this query.
data:image/s3,"s3://crabby-images/634f5/634f5b3d857f66668afbb4d38a723b09c1ae9edb" alt=""
I have the same results I achieved for last week’s method. Next time, I will look at a more complex solution for extracted data where the item data is not split into two rows for every customer.
Come back next time for more ways to use Power Query!