Power Query: Functioning Columns
31 July 2019
Welcome to our Power Query blog. Today, I create a function to add a column to a table.
Back in Power Query: Splitting Up is Not so Hard to Do, I divided a column containing a full name into first and last name columns, viz.
data:image/s3,"s3://crabby-images/5ae81/5ae81b61be4ca2efc06628664e8bcc14ded07027" alt=""
Since this is a common scenario, I want to create a function that I can apply whenever I have a full name column that I need to split up.
data:image/s3,"s3://crabby-images/fde6a/fde6a607a7c1285dee3308e87144b78a7b929d7a" alt=""
I need to convert the M code I used to split my column into a function. My original code looked like this:
let
Source = Excel.CurrentWorkbook(){[Name="Table8"]}[Content],
#"Changed Type" = Table.TransformColumnTypes(Source,{{"Employee", type text}}),
#"Split Column by Delimiter" = Table.SplitColumn(#"Changed Type","Employee",Splitter.SplitTextByDelimiter(" ", QuoteStyle.None),{"Employee.1", "Employee.2"}),
#"Changed Type1" = Table.TransformColumnTypes(#"Split Column by Delimiter",{{"Employee.1", type text}, {"Employee.2", type text}})
in
#"Changed Type1"
To begin, I create a new blank query from the ‘From Other Sources’ option of the dropdown from ‘New Query’ on the ‘Get & Transform’ section of the ‘Data’ tab.
data:image/s3,"s3://crabby-images/5d213/5d2135cb72927672732b62dba0f7e5aeeb81352d" alt=""
I simplify the code and rename my function to fnSplitName.
data:image/s3,"s3://crabby-images/f066b/f066b6282882c69e731d7fdfa0595b7e3b5fb979" alt=""
The M code I have used is:
= (mytable as table,fullname as text, column1 as text, column2 as text) => Table.SplitColumn(mytable,fullname,Splitter.SplitTextByDelimiter(" ", QuoteStyle.None),{column1, column2})
This code transforms a given column into two columns by splitting at the first space. I can now use it to transform my original data.
data:image/s3,"s3://crabby-images/f6bcf/f6bcf3724e1055f209bf67081372f310cc816e2f" alt=""
When I invoke, I get a new query with my results:
data:image/s3,"s3://crabby-images/074d2/074d2969de748816d096447612d5d460bb139992" alt=""
I could also use the function in my query:
data:image/s3,"s3://crabby-images/35726/35726f3527f13c1e6f58028c162367a9c71c47fb" alt=""
When I execute this step, I get the following results:
data:image/s3,"s3://crabby-images/7963d/7963db06ae785286b430f378c3af7527a26ddf9c" alt=""
I could tweak my function to create a copy of the column to be split if I wanted to keep it, and this function will work for any column that I want to split into two using a space. By adding more parameters, I could make it more flexible, but there is a risk of making the function too complex to be useful.
Come back next time for more ways to use Power Query!