Power Query: Revision Time – Part 11
19 June 2024
Welcome to our Power Query blog. Today, I continue to create a refreshable revision timetable by randomising the subject slots I need for the timetable.
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/09968/09968df899e607bc5b28e91da76c3d297a82c0e0" 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/88fe9/88fe9b75bbf5e05e85bc3a5240ba909afadacf83" 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/8cbaf/8cbafe730ac5e178378314d5347a9a6ba54c9b24" 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/cc7f7/cc7f72e33c39d24509753aba3141c7b5d2018055" alt=""
I created the Availability query by taking a copy of Subjects, and amending it:
data:image/s3,"s3://crabby-images/11957/1195762b24a98c6637af860cf5293e65c53c48ef" alt=""
In Part 2, and Part 3, I calculated the number of subjects and the number of slots on Availability.
This gave me both totals:
data:image/s3,"s3://crabby-images/b5cb8/b5cb88831c7436651ea12e049ddd91e83153b28b" alt=""
In Part 4, I calculated how many times each subject will appear in a new query, remembering to round up to whole slots.
This told me the number of slots that each subject should have for my example is three [3]:
data:image/s3,"s3://crabby-images/d2aa6/d2aa650648174395348ff7f814a29803317543db" alt=""
In Part 5, I created a table where each subject appeared three times (i.e. the number of times given by Subject_Slots).
data:image/s3,"s3://crabby-images/eb3b2/eb3b271452a2c745eca4d98e11fc11b71d430868" alt=""
In Part 6, I randomised the order of the slots ready to add to the timetable:
data:image/s3,"s3://crabby-images/92480/9248035028e7841d3064c26492870b98ae93ba4c" alt=""
In Part 7, I took a reference copy of the query Availability which I called TimeTable and began to transform it so that it is ready to receive the slot data.
data:image/s3,"s3://crabby-images/e4b61/e4b611736854fb282e74ee36f4d2bf8b6263d9ba" alt=""
In Part 8, I appended the slot number data to the rest of the TimeTable query.
data:image/s3,"s3://crabby-images/89b61/89b614eadd48bcd70de20f8fcdbb64afb7e1fa17" alt=""
In Part 9, I removed the duplicate values.
data:image/s3,"s3://crabby-images/78116/781164a33157f7f74b9c4c79cc9c5b6665733e23" alt=""
However, as I said in Part 8, I could have transformed the data in TimeTable by merging instead of appending, and I looked at that last week:
data:image/s3,"s3://crabby-images/9f429/9f42947cb49aa385bd1fe0c96b107f4f7c17802e" alt=""
Back in the TimeTable query, it’s time for me to merge with the Random_Subject query. I choose to ‘Merge Queries’ from the Home tab, and link Slot Number of TimeTable to Index of Random_Subject:
data:image/s3,"s3://crabby-images/d10f2/d10f252bb3dc084e000d1b7aecd81541a7844236" alt=""
I am using the default ‘Left Outer’ join – note that I have 42 matches, which is the number of subject slots I have generated. I click ‘OK’:
data:image/s3,"s3://crabby-images/72459/724592989bb3311c9605d64aa09a45eea26ead01" alt=""
I only need to extract the Subject from the Tables in column Random_Subject:
data:image/s3,"s3://crabby-images/26f68/26f6813f67038337026cb60fdc1a8f55bfcaf899" alt=""
Rather than two [2] columns, Value and Subject, I need a single column that either contains ‘x’ or the contents of Subject. If I am always going to use ‘x’ as my unavailable indicator, I could just replace the null values with ‘x’ in Subject. However, strictly speaking, this is hard coding. Instead, I will create a ‘Conditional Column’ from the ‘Add Column’ tab:
data:image/s3,"s3://crabby-images/faaaf/faaaff7129dc7755d3a27436b1a01a6eca17dc1a" alt=""
The logic I have used is that if the value in Subject is null, I populate the new column Slot with the value in Value. Otherwise, I populate the new column Slot with the value in Subject.
data:image/s3,"s3://crabby-images/e15f2/e15f2b40aa21a78d0cc2f3e0d095e27820e97f96" alt=""
Now, I can select the columns I wish to keep (Time Slot, Attribute and Slot), and right-click to ‘Remove Other Columns’.
data:image/s3,"s3://crabby-images/037c0/037c00f8d5ed496bad0c230c5898bd051100f146" alt=""
Finally, I need to pivot the Attribute column:
data:image/s3,"s3://crabby-images/3fed8/3fed8aa297b2db69af6850d42c97ea79ff485dfe" alt=""
The new columns created will contain the values in Slot. I need to choose ‘Don’t Aggregate’ from the ‘Advanced options’:
data:image/s3,"s3://crabby-images/c4053/c40535e3ed7a6d71db6d8012e953cb202e29d549" alt=""
This gives me the timetable I need:
data:image/s3,"s3://crabby-images/3564a/3564a9fddbc7b8b67b3bd08b4af39e2469f4ea90" alt=""
Next time, I will load this query and show how it works.
Come back next time for more ways to use Power Query!