Power Query: Revision Time – Part 3
24 April 2024
Welcome to our Power Query blog. Today, I continue to create a refreshable revision timetable by calculating the number of slots available.
As my salespeople take a well-earned break, many students here in the UK are preparing for exams in the summer. To help my own offspring get organised, I volunteered to create a refreshable printable revision timetable. This is the result:
data:image/s3,"s3://crabby-images/a3e69/a3e69fc12ef4f07f9580054ae8f071db10b9d110" alt=""
I needed a list of topics, and to begin with, I created extra entries for topics that required more timeslots:
data:image/s3,"s3://crabby-images/469ad/469ad2d26f3cbbc2b6919fd4e99090c99dbea22d" alt=""
We agreed on half-hourly slots, and I created a grid so that my daughter could indicate the slots that she wouldn’t be able to revise.
data:image/s3,"s3://crabby-images/7c5a7/7c5a76c232040aa225b8bc9a898e1a25e2b746b6" alt=""
When I first designed the solution, I included some Excel functions, but since this is a Power Query blog, I will ensure that I only use Power Query functions (apart from some formatting at the end!).
In Part 1, I converted my data into two [2] Tables: Subjects and Availability. I extracted Subjects to Power Query.
data:image/s3,"s3://crabby-images/f7cbe/f7cbe37d2659b5d10fe406940379db065aee8967" alt=""
I created the Availability query by taking a copy of Subjects, and amending it:
data:image/s3,"s3://crabby-images/2c5f4/2c5f46b0959d0432d44632e9d9641c4d6e878168" alt=""
Last time, I calculated the number of subjects by referencing the Subjects query and grouping the results. This gave me the Subjects_Total query, consisting of a number:
data:image/s3,"s3://crabby-images/6e575/6e5751c5648ea3f852c20dfe0b3f33e9c5f34aa8" alt=""
Calculating the number of slots on Availability will require a difference approach, since I need to consider the values in multiple columns:
data:image/s3,"s3://crabby-images/380fc/380fc5e07e05b6f4e0d3eba146232545f5c49069" alt=""
I will start by creating a reference query from Availability in the same way that I did for Subjects. I will call it Slot_Total:
data:image/s3,"s3://crabby-images/9221f/9221fa310127830f10dc3f4ce4c963d22ef1096b" alt=""
To get all the slots available in one column that I may group, I could unpivot the day columns. However, at the moment, the available slots contain the value null:
data:image/s3,"s3://crabby-images/514b3/514b3b7328f564a1da2022a35df9e80eaeb1be39" alt=""
If I were to select Time Slot and right-click to ‘Unpivot other columns’:
data:image/s3,"s3://crabby-images/3ac35/3ac354d3ef6850cbc31cca7f1a7f284fa894d98b" alt=""
I might think I have all the slots in one column. However, if I look at the filter options, I only have the slots with value ‘x’: the null values have been removed during the unpivot process.
data:image/s3,"s3://crabby-images/35cd6/35cd673924cb39ffc3bdbbcf709484ce655a74a7" alt=""
To rectify this, I need to replace the null values with an empty space. I will insert a step after the Source step. I select all columns by selecting any column heading and using CTRL + A. I access the right-click menu:
data:image/s3,"s3://crabby-images/d4cb5/d4cb5422ded48b9469ba17a64f74066c23e243a1" alt=""
I receive a warning telling me I am inserting a step, and I choose to Insert:
data:image/s3,"s3://crabby-images/f74d0/f74d0d04371102eecacc8a678ca5ea40b1c05041" alt=""
In the dialog that appears, I choose to replace any null value with an empty cell:
data:image/s3,"s3://crabby-images/744ee/744ee1de8e4d3c0b820abf4e054b283802dd9b03" alt=""
I click OK and go to the last step:
data:image/s3,"s3://crabby-images/c1c7e/c1c7e722c2845687b826e4b4f1d77553462fdfe7" alt=""
The blank values have been included, and I may uncheck the ‘x’ value:
data:image/s3,"s3://crabby-images/6ac6c/6ac6c7f35dfef4cbba0afeeca70bc57019954c16" alt=""
This gives me all the available rows, and I may group them and drill down into the total cell using the same method I used last week:
data:image/s3,"s3://crabby-images/90c25/90c257e33ad494743fa2a93e5edeeef03982509d" alt=""
Now I have the number of subjects and the number of slots, I can calculate how many times each subject will appear. This is where I will continue next time.
Come back next time for more ways to use Power Query!