Power Query: Dating Options
21 April 2021
Welcome to our Power Query blog. This week I look at how to deal with dates in a variety of formats.
I have some dates in various formats in Excel that I am going to upload to Power Query.
data:image/s3,"s3://crabby-images/b1bb8/b1bb818a2f402c0c1e36865ebc6c6c5577f69bfb" alt=""
I upload the data to Power Query using ‘From Table / Range’ in the ‘Get & Transform Data’ section of the Data tab.
data:image/s3,"s3://crabby-images/b5a6c/b5a6c2854c5e5ffcd546f3d2d807cbf644bfa72b" alt=""
I choose ‘My table has headers' and upload my data.
data:image/s3,"s3://crabby-images/fcfb1/fcfb17a81f3c8546762686aac8552773f786e20f" alt=""
The Power Query engine has tried to make sense of the dates. The M code applied to change the types of the columns is:
= Table.TransformColumnTypes(Source,{{"UK(Day/Month/Year)", type date}, {"US(Month/Day/Year)", type text}, {"Year/Month/Day", type date}, {"DayMonthYear", Int64.Type}, {"Day?Month?Year", type text}})
This means that it has recognised UK(Day/Month/Year) and Year/Month/Day as dates, but has left US(Month/Day/Year) and Day?Month?Year as type text. This makes sense because I am based in the UK and that is my locale. Interestingly, DayMonthYear has been treated as a whole number (Int64.Type).
I would like all the date columns to be transformed as dates, so I will look at each column in turn.
I will start by seeing what happens if I set the data type of date for US(Month/Day/Year).
data:image/s3,"s3://crabby-images/f8afc/f8afc9d2e7f6c8d202b0f6d366c0b3510d7dbee0" alt=""
I can do this on the Transform tab where there is a dropdown for ‘Data Type’
data:image/s3,"s3://crabby-images/98597/985972e7ea28945611254d6c025564dec5d05d02" alt=""
Since all that has happened so far is that Power Query has determined data types, I am invited to add this change to the existing step, which I do.
data:image/s3,"s3://crabby-images/0b08c/0b08ce98aa0453bdac7967d241a3566460e67046" alt=""
This is not what I want and could be confusing if I didn’t have days larger than 12. I need to help Power Query understand the format of this date. Since the date format is associated with a different locale, I can change the locale for this column.
data:image/s3,"s3://crabby-images/891e7/891e7d89d238df835e7e37dff8ee87fc28f7695f" alt=""
If I click on the date icon next to the column name, I can access a dropdown list. Right at the bottom is an option to specify ‘Using Locale’. I choose this option.
data:image/s3,"s3://crabby-images/99ad9/99ad95800470ae5a7b2774f2a3b90b486eb708a1" alt=""
I choose Data Type Date and Locale 'English (United States)'.
data:image/s3,"s3://crabby-images/6a208/6a2088336198a7d9b82a7357671717783e829e2c" alt=""
The data type and the display are now correct, and there are no errors. Next, I repeat the process for DayMonthYear, which is currently a whole number.
data:image/s3,"s3://crabby-images/52613/5261311d874a6575aa64f4bbcb57b6fea5bf31d2" alt=""
Changing to type Date gives me errors. Since this is not in a recognised locale format, I need to reformat it using some M code. I create a custom column from the ‘Add Column’ tab.
data:image/s3,"s3://crabby-images/76594/76594b35a8b3f5afc04ef0ff3fad80ecee33d620" alt=""
The M code I have used is:
= Text.Start(Text.From([DayMonthYear]),2) & "/"
& Text.Middle(Text.From([DayMonthYear]),2,2)
& "/" & Text.End(Text.From([DayMonthYear]),4)
This means I am converting the column to text and then taking the first two characters (the day), adding a “/”, then taking the next two characters (the month) and adding another “/”, and finally adding the last four characters (the year).
data:image/s3,"s3://crabby-images/ebfff/ebfff817c8d2dcb94d4c6f8f6f716ded56c8d0f8" alt=""
I can now convert this to a date.
data:image/s3,"s3://crabby-images/c9dc4/c9dc46181ebb78ed50ab31bb46acc39ad465277f" alt=""
My final column is Day?Month?Year, which is a mixture of properly formatted dates and dates missing the separator. The rule of thumb here is that I have to cater for the most difficult case, so I need to remove the separators. I can do this by right clicking and using ‘Replace Values’.
data:image/s3,"s3://crabby-images/1369d/1369d5cc1dcc2f5e7d4bdb53cda38a12a8188b75" alt=""
This will leave me with all the data in the same format and I can use the same M code as before. If I had a lot of dates in this format, I would create a function to do this.
data:image/s3,"s3://crabby-images/8740d/8740deefa8ea9ed58321da661a04a5526dcae8cc" alt=""
The M code this time is:
= Text.Start(Text.From([#"Day?Month?Year"]),2) & "/"
& Text.Middle(Text.From([#"Day?Month?Year"]),2,2)
& "/" & Text.End(Text.From([#"Day?Month?Year"]),4)
Note that this time I have to use “#” and put the column name in quote marks (“”) so that the question mark (“?”) is not treated like a special character.
I change the new column to a date and rename the custom columns. My dates are now all formatted correctly.
data:image/s3,"s3://crabby-images/9879a/9879a68314844596eb517a871e698c3ad948c2e5" alt=""
Come back next time for more ways to use Power Query!