Power Query: Next (Row) Once Again Please
26 February 2020
Welcome to our Power Query blog. This week, I look at yet another solution to my “February problem” referencing other rows.
John, my reliable imaginary salesperson, has been filling in data again. This time, I have some information on items purchased by customers in December:
data:image/s3,"s3://crabby-images/2834f/2834fc1bb4914066e4a735d5fc95543db270fbad" 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. Unlike the data for last week, this time one of the item codes does not have a description on the next line, so the two previous approaches (detailed last week and the week before) won’t work.
This week, I look at a solution where I point to the table in the previous step.
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/38c6d/38c6d960d9889b87db3fa6f5a4d625b7e0dfb0ac" alt=""
My first step is to add an index to the table; I can do this from the ‘Add Column’ tab.
data:image/s3,"s3://crabby-images/4d18f/4d18f6ab011675686fb2e75541e0076ed9ccacdd" alt=""
I choose to start the index from zero (0).
data:image/s3,"s3://crabby-images/7234e/7234e65bf162f77fc112c5d18e3552673b8dd694" alt=""
I add a custom column from the ‘Add Column’ tab.
data:image/s3,"s3://crabby-images/d2f0b/d2f0bfeead609a05070b8ffee9a62a126dc8fdd8" alt=""
My new Description column will point to the Item Code/ Description value for the next row if Customer is null on the next row.
data:image/s3,"s3://crabby-images/61ea5/61ea530447825b9dc145b5b8802404fe7cf1d782" alt=""
The M code I have used is:
= if #"Added Index"{[Index]+1} [Customer] = null then #"Added Index"{[Index]+1} [#"Item Code/Description"] else null
‘Added Index’ is the name of the previous step, and represents the table created at the previous step.
data:image/s3,"s3://crabby-images/d8ac0/d8ac0256b34c7bae99987df8f602f8b01a05aa9d" alt=""
This looks good; now I just need to remove the rows where Customer is null.
data:image/s3,"s3://crabby-images/7aa29/7aa294531c074fbc20392ea04396de6e42008461" alt=""
Once I click ‘OK’, I should have all the data I need in each row.
data:image/s3,"s3://crabby-images/76672/766729afc4a457033346ce3b6478de83ad26bc91" alt=""
I ‘Close & Load’ my data to Excel.
data:image/s3,"s3://crabby-images/92706/9270652e38cd46b4ca148b53d4bbed72f65315d0" alt=""
Come back next time for more ways to use Power Query!