Power Query: Time for a List
20 November 2019
There are three M functions in Power Query that will allow me to create a time dimension:
- List.Dates(start as date, count as number, step as duration) as list
This returns a list of date values of size count, starting at start. The given increment, step, is a duration value that is added to every value - List.Times(start as time, count as number, step as duration) as list
This returns a list of time values of size count, starting at start. The given increment, step, is a duration value that is added to every value - List.DateTimes(start as datetime, count as number, step as duration) as list
This returns a list of datetime values of size count, starting at start. The given increment, step, is a duration value that is added to every value.
I start with the List.Dates() function. I create a new blank query as follows:
data:image/s3,"s3://crabby-images/0e875/0e8751e631a023f5afa10e7981e0322ce177b8a5" alt=""
I create a new step.
data:image/s3,"s3://crabby-images/a4e00/a4e006186a1f03ded90b4ce369356463d8836e1b" alt=""
The M code I am using is
= List.Dates(DateTime.Date(DateTime.LocalNow()), 7, #duration(-1, 0, 0, 0))
which takes the current date and subtracts a day a total of seven (7) times.
data:image/s3,"s3://crabby-images/488d6/488d6328833f061c53f00adefa3bd6a209a1bf10" alt=""
This gives me the last seven days. I can convert my list to a table using ‘List Tools’, and I rename my new column Date.
To show how List.Times() works, I add a new ‘Custom Column’ from the ‘Add Column’ tab.
data:image/s3,"s3://crabby-images/4f39f/4f39f72acc7656dd323ad623c74ec777f24ad0f4" alt=""
The M code I have used is:
= List.Times(#time(0, 0, 0), 96, #duration(0, 0, 15, 0))
There are 96 quarter-hours in 24 hours, so this will divide each day into 15-minute segments.
data:image/s3,"s3://crabby-images/52900/5290090df58fced833104eb66651d1f4a6a7a6bd" alt=""
I need to expand my list into rows.
data:image/s3,"s3://crabby-images/27991/2799176c73735cacf97cf50793480d6169e020f8" alt=""
I choose to ‘Expand to New Rows’:
data:image/s3,"s3://crabby-images/2370f/2370f42171ea1c36a62166ce72ef4ab2490939cb" alt=""
I could combine these columns, if I wish, by creating a new custom column.
data:image/s3,"s3://crabby-images/5c069/5c069813b3bf38a67db50cb1e1b6e232b108239c" alt=""
This will give me a new DateTime column.
data:image/s3,"s3://crabby-images/9a9c5/9a9c53dda3fc4cb6406b560cd9dde245c33edaf1" alt=""
List.DateTimes() allows me to create datetime entries at intervals starting from a particular point in time, for example, now. I can show this in a new blank query:
data:image/s3,"s3://crabby-images/4b552/4b552f62a2631ce8d429cfc6267e98103d7f9e55" alt=""
The M code I have used is:
= List.DateTimes(DateTime.LocalNow(),672, #duration(0, 0, 15, 0))
which gives me 96 x 7 intervals of 15 minutes (i.e. the next seven days).
data:image/s3,"s3://crabby-images/b4dd3/b4dd364b8dfd5c6ef3f4f7002ee7fc80dc836601" alt=""
I can convert and rename as before.
data:image/s3,"s3://crabby-images/91165/91165572841cb4437391e87e24db4827667678ae" alt=""
Come back next time for more ways to use Power Query!