Power Query: Splendid Splitting
23 May 2018
Welcome to our Power Query blog. This week, I look at splitting data using a variety of delimiters.
I have some data for my ever-reliable fictional salespeople. As usual, the data is not in a format I would like!
data:image/s3,"s3://crabby-images/d81d7/d81d78bd6c513bb9022ed138b453eeaaea1a0b04" alt=""
Basically, I have a list of which salespeople are attending sales conferences and who is in charge at each one. Naturally, I’d like to put this data into a more useful table. What I would prefer is a list of pairings. I need to make sure I have a way of identifying which data is my sales conference location, which I why I have put ‘Location:’ before each city. I start by creating a query ‘From Table’ in the ‘Get and Transform’ section on the ‘Data’ tab.
data:image/s3,"s3://crabby-images/e52b4/e52b4617f8d21e6351f5b03ff585003662cb6ff9" alt=""
I want to convert this data into a list of pairings, and the best way for me to do this is to tell Power Query what the delimiter is. However, I don’t want to actually split the column up at this point, so I won’t be using the ‘Split Column’ on the UI (user interface). Instead, I will be using some M code. The function I am using is
Table.TransformColumns(table as table, transformOperations as list, optional defaultTransformation as nullable function, optional missingField as nullable number) as table
I have a similar step already created for me to change the type (shown on the previous screenshot), so I can work out what my function needs to be.
= Table.TransformColumns(#”Changed Type”, {{"Sales Conferences", Splitter.SplitTextBy Delimiter(“, “), type text}})
This converts each of my column entries into a list as shown below:
data:image/s3,"s3://crabby-images/68d3b/68d3b143335369d2d98a3c6c41e0beac037ce0f3" alt=""
Now I need to extend this so that I have a long list, with all my lists contained within. In order to do this, I convert my table to a list in the ‘Transform’ tab.
data:image/s3,"s3://crabby-images/d769d/d769dfd6505ebe2f51319eb19fb2dc49f7581b54" alt=""
My data is now a list of lists, and I need to convert it back to a table so that I can have one long list. This is made possible by the ability to expand the data, as I will show shortly.
data:image/s3,"s3://crabby-images/f3c47/f3c4785324108c3e18f714bb6d214bd2ecb42cc9" alt=""
I don’t need a delimiter for this part, so I take the defaults.
data:image/s3,"s3://crabby-images/7883e/7883ef6d300ead3e9293b26ef0966e7900c8e312" alt=""
Now I have my table again, but I have the option to expand my columns, allowing me to view my separated data in one long column.
data:image/s3,"s3://crabby-images/28b2e/28b2e1b94b01805b0975ac139030b6d03607653f" alt=""
Once I ‘Expand to New Rows’ I can see all of my data.
data:image/s3,"s3://crabby-images/a2d5c/a2d5c5daaeb9248da1fb329c78bd08e2d72cb4f7" alt=""
I need to pull out the sales conference locations and to do this I create a ‘Conditional Column’ from the ‘Add Column’ tab.
data:image/s3,"s3://crabby-images/a999a/a999a5f7cc83836cabbcc7ef6c21c71702be2d77" alt=""
This new column will be populated with my location if the text contains ‘Location:’
data:image/s3,"s3://crabby-images/59fed/59feddec0e8653bcb3d31db5a0ce633f9b336e93" alt=""
I can right click on my new column and ‘Fill Down’.
data:image/s3,"s3://crabby-images/fdc2d/fdc2d5b0b4b448a225946bf9764d443f0b3fea20" alt=""
This is starting to look like my goal. Now I may swap my columns around and remove anything where Column1 contains ‘Location:’. I then rename Column1.
data:image/s3,"s3://crabby-images/be2e7/be2e727a4caf8932bd50cc5df2dd952dd60e2ec4" alt=""
I decide that the ‘Location:’ has been useful to identify the cities, but now it has to go! I split the column by delimiter (right click or use the transform menu).
data:image/s3,"s3://crabby-images/5cdde/5cdde6dd0db3ff47ab0ff1e1d8605a041282980c" alt=""
I can now get rid of the Location.1 column and rename the other location column. I ‘Close & Load’ to Excel.
data:image/s3,"s3://crabby-images/bca5e/bca5e9981b988c2e78f85d8831a229cd2cf213f2" alt=""
Now to test my query. In my original Excel data, I try adding a new location (Leeds) and a new salesperson ‘Sam’, who will attend the conferences in Leeds and London.
data:image/s3,"s3://crabby-images/7db9e/7db9e6a27b11b8b597370d150f578fcd3b6f2f1c" alt=""
After refreshing my query, the new salesperson Sam appears in both locations:
data:image/s3,"s3://crabby-images/7b9a9/7b9a9b57922996bc302ed50fbde3117e7dacb78e" alt=""
Want to read more about Power Query? A complete list of all our Power Query blogs can be found here. Come back next time for more ways to use Power Query!