Power Query: Fixed Expression
16 June 2021
Welcome to our Power Query blog. This week, I look at the M function Expression.Constant().
I have different types of constant data in each column as follows:
data:image/s3,"s3://crabby-images/19d7b/19d7b355a260b772b6e8956a318b2237187c0eb2" alt=""
I am going to use the following function to show how data like this is created in M code:
Expression.Constant(value as any) as text
This returns the M source code representation of a constant value.
I will create a custom column on the ‘Add Column’ tab for each of my columns.
data:image/s3,"s3://crabby-images/0138b/0138ba9024ce944d1237cd43df0ee5bad006dff1" alt=""
The results for Last Name are:
data:image/s3,"s3://crabby-images/ed0d6/ed0d6717d83a2a29988dd1b1f2051637f82c6985" alt=""
For text values, I get the original text in speech marks (“”). I would argue with the Microsoft definition, as the value returned is type Any, not Text. This process will be repeated if I apply Expression.Constant() to EC Last Name.
data:image/s3,"s3://crabby-images/702a2/702a25eb4d6dbcbfdc9d07c074d0f942b926b929" alt=""
Now I have two speech marks around each quotation mark. Curious to see what happens next? Me too…
data:image/s3,"s3://crabby-images/83c1e/83c1e03208f365110f73c5822eaad8917d2f7eed" alt=""
So, I am adding two, then four, then eight speech marks. That’s enough for that one, I think. On to Employee ID:
data:image/s3,"s3://crabby-images/918e6/918e6d836ae041f1a63ae67c7ddd5ae413d161ca" alt=""
My numerical value is simply converted to type Any. Applying Expression.Constant() to EC Employee ID would just add speech marks and I don’t want to do that again!
The next column is Start Date:
data:image/s3,"s3://crabby-images/36db7/36db70dab09ef9aef8962d451667d47d8afd2242" alt=""
This time, the value returned is the M code that would be used to create the date from the base values of year, month and day.
data:image/s3,"s3://crabby-images/b334b/b334be32480d13d058aef33517239ccab411fc3a" alt=""
Similarly for Duration, I get the M code to create the duration from the number of days, hours, minutes and seconds.
data:image/s3,"s3://crabby-images/c607b/c607b52b9f0f9396fea57c7c19da79ae3597394f" alt=""
Finally, I get a similar result for Time, where I have the M code to create the time value from the number of hours, minutes and seconds.
Next time I’ll look at a related function Expression.Evaluate().
Come back next time for more ways to use Power Query!