I have received some sales data from John, my favourite imaginary salesperson. He’s decided to merge some of his data.
data:image/s3,"s3://crabby-images/a836c/a836c737b8fb456f7a02c2724cf273871ec08861" alt=""
I have a list of companies on each line, instead of one row for each company. I want to have one row per company so that I can link to other company data.
I start by extracting my data to Power Query using ‘From Table’ on the ‘Get & Transform’ section of the ‘Data’ tab:
data:image/s3,"s3://crabby-images/822ee/822eedb2ec98aa7defa1ba13668af1d60f722b6e" alt=""
I keep the headings and create my table.
data:image/s3,"s3://crabby-images/bf654/bf654599456975e064b236c8691f38483c074268" alt=""
I want to split the column Company. I select this column and right-click to see the options:
data:image/s3,"s3://crabby-images/8b3d9/8b3d92f3dc1611618cb9ef043ae4732bd127a941" alt=""
I can split my column ‘By Delimiter…’, so I choose this option.
data:image/s3,"s3://crabby-images/6dd71/6dd718212cfc0ffa8e19ce9daa00f9ea34237483" alt=""
I can choose to split by semicolon (;) – however, I don’t want to split into multiple columns, as each separate piece of data will be a company, so I look at the ‘Advanced options’ available.
data:image/s3,"s3://crabby-images/be6d4/be6d4ba326df75021711a37061b061e6f9022e5c" alt=""
I can split into rows, so I choose this option instead.
data:image/s3,"s3://crabby-images/5d236/5d2363548373a6e3dbc79fe22d4e3acf5f80022a" alt=""
I now have a row for each company, with one simple step (and no M code knowledge required!). The generated M code is:
= Table.ExpandListColumn(Table.TransformColumns(#”Changed Type”, {{“Company”, Splitter.SplitTextByDelimiter(“;”, QuoteStyle.Csv), let itemType = (type nullable text) meta [Serialized.Text = true] in type {itemType}}}), “Company”)
This has used the M function Table.ExpandListColumn():
Table.ExpandListColumn(table as table, column as text) as table
Given a column of list data in a table, this creates a copy of a row for each value in its list.
Power Query has converted the Company column to a column of lists by using Splitter.SplitTextByDelimiter(), and then converted that list into rows. In this case, my data was delimited by a simple semicolon, but there are also options to use special characters, making this a very powerful function when dealing with complex columns.
data:image/s3,"s3://crabby-images/42293/42293c3292ee944a79e46f355ab8439abfc9fcc5" alt=""
Ref: https://www.sumproduct.com/blog/article/power-query-blogs/power-query-rows-of-columns