Power Query: Calendar Creation – Going for Dates
19 April 2017
Welcome to our Power Query blog. Last time I set up the tools that I will use to create a calendar – today I will populate my calendar and add some useful columns.
As I described in Calendar Creation – Preparing for Dates building a calendar using Power Query is a collaboration between Excel and Power Query. The four steps are:
- Create a table called Parameters in an Excel Worksheet to hold the calendar boundaries
- Create a function fnGetParameter which uses the calendar boundaries as its parameters
- Build the basic dynamic calendar framework
- Add any required calendar columns.
Having created Parameters and fnGetParameter last time out, this time I will concentrate on the last two steps: building my calendar framework and adding useful columns.
Build Calendar Framework
Now I have set up my parameters and created a function to extract the values, I can begin to build my calendar.
In the worksheet I created last time, I will start by creating another blank query, following the same procedure as before, and this time I will call it Calendar: The process I follow to create my calendar framework is to build a list of dates between the two parameters that I have specified.
I begin by entering a simple list in the formula bar:
= {1..10}
data:image/s3,"s3://crabby-images/64e96/64e96c3dd76b41a8d2548addd9ffd435e85c7f7c" alt=""
As shown above, this gives a column of 10 numbers, which I can prepare for calendar format by transforming. Notice that Power Query automatically presents me with options for transforming a list.
In the ‘Convert’ section I choose to convert my list ‘to Table’, and take the default options:
data:image/s3,"s3://crabby-images/64111/6411150518a634a73a20675048a67f4a9738d12a" alt=""
In the resulting table I right click my column and ‘Change Type’ to ‘Date’, and then rename my column Date.
data:image/s3,"s3://crabby-images/23950/23950dfc6585550cf81061320e7da120272b5ace" alt=""
They may not be current, but they are dates! Now I need my parameters.
I choose the ‘Advanced Editor’ from the ‘Home’ section. The editor shows the lines already created as a result of the transforming I have done. The ‘Source’ step currently shows my original list of 10 numbers: I need to change the source to look at my parameters instead of 1 and 10. Therefore, after ‘let’ and before the ‘Source’ line, I need to add my parameters, which I will call startdate and enddate thus:
startdate = fnGetParameter(“Start Date”),
enddate = fnGetParameter(“End Date”),
data:image/s3,"s3://crabby-images/2104d/2104d8bdf3a42de99807014b019b5b142a435432" alt=""
However, if I try this I get the following error:
data:image/s3,"s3://crabby-images/eba34/eba3495b9a519b6fc764a40ae24a82675939c9e1" alt=""
This is because I started with a list of numbers and then I tried to use dates instead. I need to express the dates as numbers, so I need to use the Number.From function:
startdate = Number.From(fnGetParameter(“Start Date”)),
enddate = Number.From(fnGetParameter(“End Date”)),
When I use these definitions instead, my query returns a column of dates:
data:image/s3,"s3://crabby-images/d01d4/d01d4d3ac234513b4d6b2085021446e8ae4c5d46" alt=""
Adding More Date Columns
Although I have a calendar, it is a very basic calendar. A few more columns would be useful. For this, I am going to repeatedly use the ‘Date’ section of the ‘Add Column’ tab and use the options that are shown on the dropdown below:
data:image/s3,"s3://crabby-images/39adf/39adfcf8c4fea0c752cec7b1f810925504b49034" alt=""
I choose to add the ‘Year’, ‘Month’, ‘Day’ and ‘Quarter (of Year)’ options.
data:image/s3,"s3://crabby-images/83202/832025133fc912f02c886a6afa4806440422bf3e" alt=""
On the ‘Home’ tab, I then choose to ‘Close and Load’ to see that all the Calendar entries have been created as I expected. The entries automatically appear in a separate sheet to my Parameters table:
data:image/s3,"s3://crabby-images/6ef6d/6ef6de0146cdcebaef70e04d4cad2fa55cbd4c32" alt=""
My calendar is ready for use.
Want to read more about Power Query? A complete list of all our Power Query blogs can be found here. Come back next time for more ways to use Power Query!