Power Query: Not Your Type
27 November 2019
Welcome to our Power Query blog. This week, I look at assigning types to columns.
Setting the data types when transforming data in Power Query is important. Data type specific functions, such as M date functions, will not work correctly if the data does not have the expected data type.
data:image/s3,"s3://crabby-images/2e124/2e124e0458ea44dc38019672d0f8038765a85a21" alt=""
When I extract data into Power Query, algorithms are used to determine the most appropriate data type. On the previous screen, this step is called ‘Changed Type’. The M code used is
= Table.TransformColumnTypes(Source,{{"Name ", type text}, {"Employee Number", Int64.Type}})
This sets my Name column to data type text and my Employee Number column to data type whole number.
I can change the data type from the ‘Home’ tab or ‘Transform’ tab:
data:image/s3,"s3://crabby-images/f9741/f9741c26443f39be954ef39f3089a1fc705d689b" alt=""
If I decide to change the type, I have the option of changing the ‘Changed Type’ step or by creating a new step, viz.
data:image/s3,"s3://crabby-images/9deb0/9deb03a963ee4368ba1cbb4e859d6e0b2f8ad969" alt=""
If I create a new step, I can see the M code that Power Query uses to change the type.
data:image/s3,"s3://crabby-images/8b40f/8b40f13a90b455c152a2927b29ec393ba800d4c2" alt=""
The M code is
= Table.TransformColumnTypes(#"Changed Type",{{"Employee Number", type text}})
I can also use M code to set the data types myself. I start by creating the table.
data:image/s3,"s3://crabby-images/5b525/5b5257b93ff4d7a71bb464efe7c97525e4c45be1" alt=""
The M code I have used is:
= Table.FromRecords({ [Name = "Mary", Employee_Number = 1], [Name = "Paul", Employee_Number = 18], [Name = "John", Employee_Number = 18], [Name = "Newbie", Employee_Number = 150]} )
I have not defined data types, so both columns have type ‘Any’. I can add a step to change this.
data:image/s3,"s3://crabby-images/4ddf0/4ddf09cde2bc51c7dd21c911e277146d6d7e8d53" alt=""
The M code I have used is
= type table[Name = text, Employee_Number = number]
data:image/s3,"s3://crabby-images/698f2/698f2273a73d4d2c241be476f63078a73907b5ef" alt=""
This has created a table type. I need another step to assign this type to my table:
data:image/s3,"s3://crabby-images/77759/777592c882c266431f3d1586274ad7ebccba6f87" alt=""
The M code I have used is
= Value.ReplaceType(Source, Custom1)
data:image/s3,"s3://crabby-images/4f157/4f157f6991bb078c59a5dd0e5ed5d5a0a7d7b5ce" alt=""
My Name column is now text and the Employee_Number column is a number.
I have achieved my goal in three steps, but I can do it in two. For that, I need to be able to specify the types when creating my table.
data:image/s3,"s3://crabby-images/3cf4c/3cf4c304d1c5c0b1f342b2773fe8ac24f6b4412f" alt=""
I have entered a step to create the types for my table (before I specify the data). The M code is
= type table[Name = text, Employee_Number = number]
data:image/s3,"s3://crabby-images/7a88a/7a88a4d23bbdbe95eb244aadd7cd2d11a8ccc380" alt=""
Next, I need to provide the data to populate the table.
data:image/s3,"s3://crabby-images/6b754/6b754119a17c1b4e01cf413e018e8706930c6bc6" alt=""
The M code I have used is:
= #table(Source,{{"Mary",1},{"Paul",18},{"John",15},{"Newbie",150}})
data:image/s3,"s3://crabby-images/bd0ca/bd0ca3ed580a02b02a3015104883b8521886e252" alt=""
My table has the correct column data types. I can combine these steps and achieve this in one more complicated step.
data:image/s3,"s3://crabby-images/89f91/89f9153797df68d764899fb9bb32007635e29832" alt=""
The M code I have used is:
= #table(type table[Name = text, Employee_Num = number],{{"Mary",1},{"Paul",18},{"John",15},{"Newbie",150}})
I can also use Table.FromColumns, which accepts the table types as the second parameter.
data:image/s3,"s3://crabby-images/47043/47043e6d0cffa6fde3b50fecca2b3abbb010678d" alt=""
The M code I have used is:
= Table.FromColumns({{"Mary", "Paul", "John", "Newbie"},{1,18,15,150}},type table [Name = text, Employee_Number = number])
data:image/s3,"s3://crabby-images/e9702/e97027890feebc5b2c6a53738343a0473d7114ad" alt=""
My columns have the correct data type.
There are some disadvantages to declaring data types in this way which I will look at next time.
Come back next time for more ways to use Power Query!