data:image/s3,"s3://crabby-images/a2214/a22143628c8048cfedc6b5bb4395d6099c9e6f9f" alt=""
Here's the situation:
I have a list of values and want to create one single concatenated string based on that list.
We can do accomplish this with:
List.Accumulate()
For example, I have a list:
Name
Brent
Susan
Josef
Mary
To convert into this:
"BrentSusanJosefMary"
data:image/s3,"s3://crabby-images/876fd/876fd1f686d78cae9b5c40c0539dec871cedcb20" alt=""
Here's the solution:
1. Convert your table to a list.
You can do this with in the ribbon via: Transform -> Convert to List
data:image/s3,"s3://crabby-images/89198/891986ee7d1b15ee0bd6520714d87774ebf9d669" alt="Convert to List"
data:image/s3,"s3://crabby-images/04c5d/04c5d1cce6bebce88a6235d0503a4b593c8a5cb7" alt="Converted List"
2. Insert the following code as the next Step:
= List.Accumulate(
Name,
"",
(accumulatedString, curString)=>accumulatedString & curString
)
"Name" is the variable for the list you made for #1.
"" is a placeholder for a seed. I left this as blank.
accumulatedString is our variable to keep track of the concatenated string.
curString is the variable for the current item in the list (during the loop).
data:image/s3,"s3://crabby-images/021d8/021d8a47fb04efaee2c063fa931f8e6d9a9fa695" alt="For Loop Function"
The entire M code looks like this:
let
// Standard stuff here...
Source = Excel.CurrentWorkbook()
{[Name="TableOfNames"]}[Content],
#"Changed Type" = Table.TransformColumnTypes(
Source,{{"Name", type text}}),
// Change Table to a List
Name = #"Changed Type"[Name],
// Use a Looping function to Concatenate
AllValuesString = List.Accumulate(
Name,
"",
(accumulatedString,curString) =>
accumulatedString & curString)
in
AllValuesString
Enjoy the code my fellow space travelers.
Check out some more useful(?) power query functions here.