Power Query: Mind the Gap
17 October 2018
Welcome to our Power Query blog. This week, I look at how to fill in rows when there is a gap in dates.
I have the following data from my imaginary salesperson, Mary.
data:image/s3,"s3://crabby-images/cabf6/cabf6d9d0ba4365a80b0e83452dea9d7d84ad945" alt=""
Mary has supplied me with her sales figures for May 2016. I need to add these to existing data, but there is a problem. Mary was on holiday from May 4th to May 19th, so she hasn’t created any data for these dates. I want to add the missing rows.
data:image/s3,"s3://crabby-images/8e53e/8e53efc5faf77ba877b715c9ddccbc555f8ff060" alt=""
I begin by creating a query ‘From Table’ in the ‘Get & Transform’ section of the ‘Data’ tab. I am prompted to define the boundaries of my Table (and to check that headers exist) and I take the defaults.
data:image/s3,"s3://crabby-images/f05f8/f05f8ea74f91f24d235bcb693e4ce4a64af53fb4" alt=""
Now I need to add the missing rows.
data:image/s3,"s3://crabby-images/28595/28595906ba2cd5a9264beec59c8ef3363209870e" alt=""
I start by creating a copy of the existing query, and to do this I will create a reference query. For more on the differences between reference and duplicate queries see Power Query: Cleanse, Tone and Upload.
data:image/s3,"s3://crabby-images/ee73e/ee73e7b7ef230a1ac66a27a8a73dc58214253b1d" alt=""
I now have two queries containing Mary’s data; I am going to savage this query by only keeping one row!
data:image/s3,"s3://crabby-images/8303f/8303f28cc5d22b6df492d4054fe41af5462ee966" alt=""
I can do this by using the ‘Keep Rows’ option
data:image/s3,"s3://crabby-images/e139b/e139b37870462d8e767bfa47a8925e670bfacdcc" alt=""
I choose to keep just the top row.
data:image/s3,"s3://crabby-images/e6ad9/e6ad931c57171d4f1253ad5d9edbdb8971634c93" alt=""
I create a new column by using ‘Custom Column’ from the ‘Add Column’ tab. I use this to create a list of dates from the date on the row for 31 days:
= List.Dates(#date(Date.Year([Date]), Date.Month([Date]), Date.Day([Date])), 31, #duration(1, 0, 0, 0))
data:image/s3,"s3://crabby-images/c248a/c248a38b5bf6cf985fff1b1cd1515c8133715e85" alt=""
I expand the list in Each_Date to new rows.
data:image/s3,"s3://crabby-images/146d4/146d4c0d03e6bba8d848ea5fbaaa77f96b82b1a8" alt=""
I now have a row for each date in the date range. My new column doesn’t look like a date though, so I need to change the data type ready for the next step.
data:image/s3,"s3://crabby-images/99759/99759a497bfc7a3d79eb2cc18df78e93df83aee9" alt=""
I want to simplify my query as I don’t need the original Date, Sales and Commission columns – these will come from Mary’s data.
data:image/s3,"s3://crabby-images/7e0a4/7e0a48697e6de93bfb24ec7dc19f2196f90e2a7e" alt=""
Now all I need to do is put Mary’s data back in.
data:image/s3,"s3://crabby-images/29ace/29acee365f8a8ac6c600b4de9f3e731bbc4f9dc4" alt=""
I choose ‘Merge Queries as New’ from the ‘Merge Queries’ section from the ‘Home’ tab.
data:image/s3,"s3://crabby-images/6ebcb/6ebcbf6fde16c71e516db8dc9a8f9568584811ff" alt=""
I want all the rows from my first query and matching rows (with the sales data) from my second query. I use the ‘Left Outer’ join.
data:image/s3,"s3://crabby-images/f2fec/f2feccb0b2ffa307e33f6eba46984bbe72dc9e0d" alt=""
A new query ‘Merge1’ is created, and Mary’s data is held in column Mary Data with Gap which contains a table. I choose to expand the Sales and Commission columns. I will (of course) uncheck the ‘Use original column name as prefix’ option.
data:image/s3,"s3://crabby-images/d556f/d556f9c2c8126f9bc2981db629f2f6e66f8e1683" alt=""
I now have data for each date – but it needs to be tidied. I want zeroes instead of nulls in my currency columns.
data:image/s3,"s3://crabby-images/7c0f9/7c0f90456104b746459cd907ee7f7f33845d52f7" alt=""
I can replace values to achieve this.
data:image/s3,"s3://crabby-images/00e05/00e0580b81b9e93ca85db8c92381e124af9df4f8" alt=""
I now have entries for each date so that this data can be combined with other similar data.
Come back next time for more ways to use Power Query!