Power Query: Missing in Transformation
10 June 2020
Welcome to our Power Query blog. This week, I look at a method to make column transformations more dynamic.
John, one of my imaginary salespeople, has been busy submitting his expenses. I used this same data in Power Query: Dynamic Removals, but this time, I am using another method to dynamically transform my columns.
data:image/s3,"s3://crabby-images/18a57/18a573885d9deb726f8a19c30e226e68dcf7ea35" alt=""
I extract my data to Power Query using ‘From Table’ in the ‘Get & Transform’ section of the Data tab.
data:image/s3,"s3://crabby-images/74786/74786b0b131b65b77c1bdad68a89fcf21ffb1f7d" alt=""
I change the data type on Amount, Card, Cash, Mike and Cheque to ‘Currency’.
data:image/s3,"s3://crabby-images/6dd14/6dd14b4e6d0b6ef932bf9a870ecb58b50ee718ae" alt=""
I do this by selecting my columns and setting the Datatype on the Transform tab (I could have used this option on the Home tab too).
data:image/s3,"s3://crabby-images/dcc18/dcc18a571b975dc06339184165c4e08bb048c45b" alt=""
I rename this step ‘Change to Currency’, as I am going to show what happens if John doesn’t have a column for Mike. I close and load this query and go back to my original worksheet:
data:image/s3,"s3://crabby-images/9b321/9b3218a1f12bc93e1e909a0de4455153991dc2cb" alt=""
I remove the Mike column and return to my query.
data:image/s3,"s3://crabby-images/33612/33612cbab9b0c3bf2c04892efb1c6f543e1fe3ae" alt=""
As expected, I get an error. This is because the M code in the ‘Change to Currency’ step refers to Mike:
= Table.TransformColumnTypes(#"Source",{{"Amount", Currency.Type}, {"Card", Currency.Type}, {"Cash", Currency.Type}, {"Mike", Currency.Type}, {"Cheque", Currency.Type}})
I am going to create a function that will only transform columns if they exist. To do this, I create a new blank query. I can do this from the Excel workbook by choosing ‘Blank Query’ in the ‘From Other Sources’ section of ‘New Query’ in the ‘Get & Transform’ grouping of the Data tab.
data:image/s3,"s3://crabby-images/bb22b/bb22bdb4cbc5a864177d84224684ae88d069286c" alt=""
In the Advance Editor, I add the following M code:
(table as table,
typeTransformations as list,
optional culture as nullable text) as table =>
List.Accumulate(
typeTransformations,
{},
(x, y) => try Table.TransformColumnTypes(table, y, culture)
otherwise x
)
This means that I only try and transform the column if it exists. This will work for any column transformation I wish to apply.
data:image/s3,"s3://crabby-images/5b3e2/5b3e26307535ed46035c929ac2a5b577f97f5606" alt=""
I call the function DynamicTransform.
I go back to the query which gave an error for the missing Mike column and adjust the M code in the ‘Change to Currency’ step:
data:image/s3,"s3://crabby-images/9421f/9421f890f2666969622fdcc0578aebc087cdfed7" alt=""
Instead of using Table.TransformColumnTypes, I use my new function:
= DynamicTransform(#"Source",{{"Amount", Currency.Type}, {"Card", Currency.Type}, {"Cash", Currency.Type}, {"Mike", Currency.Type}, {"Cheque", Currency.Type}})
And now, the error does not occur:
data:image/s3,"s3://crabby-images/d5817/d58174c244b7e76a2697b5dded002ae54c2b333e" alt=""
I now have a dynamic way to apply changes to John’s columns even if some of them are missing.
Come back next time for more ways to use Power Query!