Power Query: Conditional Column Splitting
30 January 2019
Welcome to our Power Query blog. This week, I look at an example where one column contains both header and detail data.
data:image/s3,"s3://crabby-images/a1bc7/a1bc748902c9c9969afd2f1a1771d24afe35ad33" alt=""
I have some tent data where the Tent Type column contains both header data, the tent size, and more detailed data, size and colour. I want to extract that data into two columns so that I have a size column, and a size and colour column.
data:image/s3,"s3://crabby-images/6d980/6d98028f4f432eba3a281e734c50e6c34e885a63" alt=""
My first step is to create a query by selecting ‘From Table’ on the ‘Get & Transform’ section of the ‘Data’ tab. The ‘Create Table’ box appears so that I can check the position of my table and indicate if there are headers.
data:image/s3,"s3://crabby-images/f98fa/f98fa22c71361eee1e57dcffb14aa406a0c0b9f4" alt=""
In order to format my Price column correctly, I replace the nulls with zero (0), by right-clicking with the Price column selected and choosing the option ‘Replace Values’.
data:image/s3,"s3://crabby-images/218f9/218f9d966926eeaf89d226772a1ae43fb029bec4" alt=""
Next, I create two conditional columns, by using the ‘Conditional Column’ option on the ‘Add Column’ tab:
data:image/s3,"s3://crabby-images/c1495/c149508596975ff6425ae7cc46e8da7b6550edc5" alt=""
and a second:
data:image/s3,"s3://crabby-images/2ee7f/2ee7f8d2245809f9ee9d5669c1a874db78749501" alt=""
Since the price is zero if Tent Type holds the tent size rather than the size and colour, I can use the value of Price to determine how to populate my new columns.
data:image/s3,"s3://crabby-images/a8695/a869574f76f26c8bf8f2ca7aefa3c1455ddf4505" alt=""
I have my two columns, and now I can complete the values in Tent Size by right-clicking and choosing to fill down.
data:image/s3,"s3://crabby-images/0ae21/0ae21928c0d0de433c3abeb8cf018aaa26e7aaa2" alt=""
data:image/s3,"s3://crabby-images/4c504/4c5041b99ae470adcd2e8f1813518a8dd98a9413" alt=""
I can now remove the rows where Price is zero or Tent Size and Colour is null by filtering on one of these columns – I choose Tent Size and Colour.
data:image/s3,"s3://crabby-images/2fe6c/2fe6cae71f36aff16dfc55b96f5c7256395fed6a" alt=""
I filter using the ‘Text Select’ option, and choose to keep those rows which are not null.
data:image/s3,"s3://crabby-images/2d193/2d1938a47d64aea547eda47372c29a32404be4da" alt=""
I can delete the column Tent Type which is now a duplicate of Tent Size and Colour, and reorder my columns:
data:image/s3,"s3://crabby-images/8be1e/8be1eeab4ed8dccdb7d857da7e289f088d4b1be9" alt=""
My tent data is now in the format that I need.
Come back next time for more ways to use Power Query!