Power Query: Revision Time – Part 4
1 May 2024
Welcome to our Power Query blog. Today, I continue to create a refreshable revision timetable by calculating how many times each topic should be included.
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/7aeda/7aeda196f165d76c7d42ead609fd1a1fa0690aab" 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/40886/408867584346f4b73cf6a82940c3109d720571de" 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/7cb4b/7cb4b7f4f75b368b492741a582a1599f05ac3679" 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/cacb4/cacb472c548dae321e9fa2ce1bdd955f102f28e4" alt=""
I created the Availability query by taking a copy of Subjects, and amending it:
data:image/s3,"s3://crabby-images/344ad/344ada4ebeb77707269f0d0959aebe79a21d999b" alt=""
In Part 2, 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/b8b6b/b8b6bf57582177301a7071fdc9e55b0cfa84867d" alt=""
Last time, I calculated the number of slots on Availability by unpivoting some of the data first, as I needed to consider the values in multiple columns:
data:image/s3,"s3://crabby-images/96630/96630d4f7973fa4cd5045287be466ae14e986591" alt=""
Solving this, I was then able to group and drill down as I had done for Subjects_Total. I now have both totals:
data:image/s3,"s3://crabby-images/716de/716de782a2aedc41e22df82e2760322adb3291d4" alt=""
I can calculate how many times each subject will appear. I create a new blank query by right-clicking in the Queries pane:
data:image/s3,"s3://crabby-images/52ae7/52ae7e6f754d553105e3a3620c438a2eae45249f" alt=""
I call the new query ‘Subject_Slots’ and I type in a very simple division, using the Intellisense to help me:
data:image/s3,"s3://crabby-images/8a799/8a799ca2fdf75e976945bdca74a49f1b1960329d" alt=""
This gives me the answer, here 2.8:
data:image/s3,"s3://crabby-images/37b3a/37b3ab7b5fbf4117f05e7fecfc65c8889bfc7148" alt=""
However, I am not interested in parts of slots. I need to round up to the nearest whole number, so that I have no empty slots. Since my current query is a number, I have a ‘Number Tools’ menu containing transformations suitable for numbers. On the Transform tab, I have the option to ‘Round Up’:
data:image/s3,"s3://crabby-images/959c8/959c8a501cb2d00c74f3bc1db18b10c3c95facbe" alt=""
This tells me the number of slots that each subject should have, in this case, three [3]:
data:image/s3,"s3://crabby-images/4c5e1/4c5e10603a5154d35e7b875e871a646a30c83fa4" alt=""
Now I know how many times each subject will appear on the timetable; I am ready to allocate the slots. Next week, I will create a query containing a row for each subject slot.
Come back next time for more ways to use Power Query!