Power Query: Revision Time – Part 2
17 April 2024
Welcome to our Power Query blog. Today, I continue to create a refreshable revision timetable by calculating the number of subjects to be studied.
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/4f213/4f213450961b6b7afda06abd926073a9aa39b4fa" 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/a70c5/a70c53d906798ecfc2618d3f56b49a7927d980bf" 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/49c1c/49c1c9709dc5aac459681fbac361589b5ff0bae4" 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!).
Last time, I converted my data into two [2] Tables: Subjects and Availability. I extracted Subjects to Power Query.
data:image/s3,"s3://crabby-images/d8b53/d8b53d9d111697fb08bfea5ade539bac7522fd2d" alt=""
I created the Availability query by taking a copy of Subjects, and amending it:
data:image/s3,"s3://crabby-images/651c4/651c41b065639250aa424f8b76bb00d2486cba58" alt=""
Now I have the subject and slot information, I need to perform some basic calculations. I could have performed this in Excel, but as this is a Power Query blog, I will be using M here.
The first number I need is the number of subjects. An easy way to calculate this begins with taking a reference copy of the Subjects query:
data:image/s3,"s3://crabby-images/ed746/ed7464d2689d6c72665f2d845a41ee4e31ef09df" alt=""
Using a reference copy means my new query will be updated if Subjects changes. I name my new query ‘Subjects_Total’ and select the ‘Group By’ functionality from the Home tab:
data:image/s3,"s3://crabby-images/e50e5/e50e563f1ad0e950762f67919b24364ea2a19809" alt=""
I have selected the Advanced options. Although the defaults in the aggregation section are correct in that I do wish to count rows, I do not want to group them by Subject. If I hover the cursor to the right of the grouping section, I have more options in Advanced mode:
data:image/s3,"s3://crabby-images/80bfd/80bfda9f27ad77d110e00760223e6a3f3a1fba33" alt=""
In particular, I may delete the grouping:
data:image/s3,"s3://crabby-images/0a8a3/0a8a352523c73041381232277574611ad2192400" alt=""
I choose to do this, and then click OK:
data:image/s3,"s3://crabby-images/914fb/914fb580701e6754cdac1ccebd8ae454027bc95d" alt=""
To access the number in the cell, I click in the cell and right-click to ‘Drill down’:
data:image/s3,"s3://crabby-images/165ec/165ec067023e4eb5f9856dfd79aebf1bdc5a1a6d" alt=""
This gives me a query consisting of a number:
data:image/s3,"s3://crabby-images/bbb89/bbb8968bba28e249918ff5da96474ee0418ef21c" 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/308f6/308f6c60673cb32a17a0978f737ed7b98820902e" alt=""
I will describe a method to achieve this next time.
Come back next time for more ways to use Power Query!