Power Query: Birthday Lists
15 November 2017
Welcome to our Power Query blog. Since I have reached the milestone of my 50th issue, I have covered a whole list of Power Query features. Talking of lists… (it’s an ellipsis, get it?)
I will start with a nice simple example – in a new query, I will create a list of consecutive numbers.
data:image/s3,"s3://crabby-images/533b6/533b675995a9d99efceadfa84d470c878da784ed" alt=""
Curly brackets (or braces) { } indicate that a list is enclosed. For whole numbers, I can define a range by giving my start and end points and separate them by an ellipsis of two dots .. to indicate that the intervening numbers should be included. Therefore, I may specify a list from 1 to 10 by entering
= {1..10}
in the formula bar.
data:image/s3,"s3://crabby-images/eecda/eecdad1c7922c4f8b887a6df2f777282fca3c0dc" alt=""
Numbers are not the only list I can create with this format; I can create a list of consecutive letters. Since letters are text, they must be surrounded by speech marks “ “.
data:image/s3,"s3://crabby-images/b0ec6/b0ec63d31a4dca9883b58a69b8d082deac92a1d7" alt=""
Using ellipsis with characters is limited to single characters though, so although I can create this list
= {“0”..”9”}
data:image/s3,"s3://crabby-images/df093/df093eadd5e0183b3b334705ca2b3f8ad403a27f" alt=""
I am not allowed to create this
= {“1”..”10”}
data:image/s3,"s3://crabby-images/c10c9/c10c91d2b9abec8c0648830552131e5fb4e2c50a" alt=""
I have to specify the whole list instead
= {“1”, “2”, “3”, “4”, “5”, “6”, “7”, “8”, “9”, “10”)
data:image/s3,"s3://crabby-images/6598e/6598e5151f343bbc860b34d7d93472a10c5c415e" alt=""
Therefore, lists with ellipses are more useful for numbers – what if I want to create a list of dates without typing them out? In this case I can’t just type the number for today as 15/11/17 or even 151117, as this is not how Power Query will recognise it – however I can use the serial number of the date. In order to get a date in serial number format, I can use the Number.From function.
Number.From(value as any, optional culture as nullable text) as nullable number
My value is #date and I need to give my date as year, month and day separated by commas. So, for today it would be:
= Number.From(#date(2017,11,15))
I create a list of the dates (in serial number format) until the end of November:
data:image/s3,"s3://crabby-images/1a585/1a5850fe2f3cc060c55880dc290006745d0aaee5" alt=""
If I want the dates to look like dates, then I need more formatting options open to me. Having created my list, if I want to transform data or merge with other tables, then I need to convert my list to a table, which is easy to do, as the options for lists are automatically displayed when I create my list.
data:image/s3,"s3://crabby-images/8da25/8da254a2dd8173f2f06e24098019bec2724f8f0f" alt=""
As I have created a very simple list I can take the defaults and create my table. In the ‘Transform’ tab, I can choose to convert my ‘Data Type’ to ‘Date’ (I could also do this from the ‘Home’ tab):
data:image/s3,"s3://crabby-images/aa9d2/aa9d24a8c1309e31828c51afd110550170a2aaed" alt=""
Thus, I have my list of dates in a recognisable format.
data:image/s3,"s3://crabby-images/1a348/1a34827d0e59a2c0ba4b6455567d34c0301ffead" alt=""
There are other ways to get a list of dates (without using the ellipsis). The List.Dates function allows more flexibility:
List.Dates(start as date, count as number, step as duration) as list
I am going to create my list again from a blank query, using this function.
=List.Dates(#date(2017,11,15), 16, #duration(1,0,0,0))
Now, since this function is more flexible, it looks more complicated. I have specified my start date as before, then I need to specify how many list entries I want and finally, what the difference is between each entry. Since I can also use this function for ‘datetimes’ the duration can be hours, minutes etc. I choose to increment by one day at a time.
That sounds complicated: if only there was some way to remind me what to enter for the List.Dates function…
data:image/s3,"s3://crabby-images/5bf6b/5bf6b2c35a94500bd781e792be0e5167ee35a911" alt=""
Now this is useful. Power Query has recognised what I am trying to do when I enter List.Dates, and I can enter the parameters one at a time.
data:image/s3,"s3://crabby-images/f6c49/f6c493956172251c4ea02dfecf53cdba922bfe2e" alt=""
I enter my parameters (I enter 1 as the step or increment as I’m assuming one day is the default).
data:image/s3,"s3://crabby-images/a3d73/a3d739372daa57dd75a245ed8c023655e4f75162" alt=""
The advantage this way, is that my dates are created in a recognisable format so I can see they are all there. There are some other interesting (well for me anyway) uses of the List functionality. I can list numbers, without using an ellipsis, and by specifying the interval:
List.Numbers(start as number, count as number, optional increment as nullable number) as { Number }
This function is very flexible too, so it looks complicated. I create a list with the following formula
= List.Numbers(3, 16, 3)
So, I am expecting my list to start at three, have 16 entries and have an interval or increment of three. As before, I don’t have to remember how to use the parameters, I can just enter List.Numbers:
data:image/s3,"s3://crabby-images/f005d/f005dc9dc84799feab7eae038f9b70c2966d9888" alt=""
So now I am expecting to see my three times table:
data:image/s3,"s3://crabby-images/f34dd/f34ddc72406eb4ab5f4a9819a95b0890cc476299" alt=""
I don’t have to stick to whole numbers; if I choose different parameters I can have a list of decimals:
data:image/s3,"s3://crabby-images/2ada0/2ada073686df98203597dd4167ef83568a8158de" alt=""
This time I expect to see my 0.3 times table.
data:image/s3,"s3://crabby-images/b0dc2/b0dc29a9504303b95d14667dbde6b7b23411c70b" alt=""
If for some reason I want to see my list in reverse, I can do this with the…
List.Reverse(list as list) as list
The list can be created using any of the methods used so far, so I can create
= List.Reverse({1..15})
data:image/s3,"s3://crabby-images/9b2f3/9b2f33131c332216aad23dd8d9ebd4c2d0288914" alt=""
Or I can reverse my three times table:
data:image/s3,"s3://crabby-images/32504/325049823925a3ee67773dbb3eb9f044fa595508" alt=""
Finally (for now), I can create a repeating list of numbers, with List.Repeat.
List.Repeat(list as list, count as number) as list
This repeats any list as many times as I want. Therefore, I can repeat the first three entries of my three times table.
= List.Repeat(List.Numbers(3,3,3),3)
data:image/s3,"s3://crabby-images/98bab/98bab05d8fc6d738d4ab4328a7641d22dd663ec3" alt=""
Come back next time for more ways to use Power Query!
Want to read more about Power Query? A complete list of all our Power Query blogs can be found here.