Power Query: Revision Time – Part 8
29 May 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=""
Last week, 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=""
Before I can merge this query with Random_Subject, I need to number the slots available.
As is often the case with Power Query, there are a number of ways I can do this, but I have chosen to filter the data I need to number and then re-merge it with the rest of the query. To make it easier to keep the order of my data, I will add an index column from the ‘Add Column’ tab before I start:
data:image/s3,"s3://crabby-images/82975/829754c082e48a2bd01ab470216f3e4bc37900ef" alt=""
Next, I filter on Value to remove the rows containing ‘x’:
data:image/s3,"s3://crabby-images/91436/91436afa9e9cb2d5e8f2e063630ced741054552a" alt=""
I may now add another index starting from one [1], which I name Slot Number:
data:image/s3,"s3://crabby-images/9fede/9fededbc5c9d23ed0297a8417e0ae5689783e8c8" alt=""
I could merge or append my data to include the other rows that I will need for the timetable. Before I start, I will rename the steps ‘Added Index’ and ‘Renamed Columns 1’ which I plan to join, to make it easier to follow the process:
data:image/s3,"s3://crabby-images/afcb9/afcb9d3eb30322ea1e4fa895dd2269d9a0af72c4" alt=""
I will look at each option: this week I append the data. In the Home tab, I choose ‘Append Queries’, and choose to append to the current query:
data:image/s3,"s3://crabby-images/9b7b5/9b7b5a1baf3036f51d5d296755c57551322d6263" alt=""
This generates the M code I need.
data:image/s3,"s3://crabby-images/3905d/3905d84d9a5e94536b6bb477b5d9d32f2a697513" alt=""
I change the code from:
= Table.Combine({#"Index Slots Only", #"Index Slots Only"})
to
= Table.Combine({#"Index Slots Only", #"Index Full Query"})
This gives me some duplicates:
data:image/s3,"s3://crabby-images/89b61/89b614eadd48bcd70de20f8fcdbb64afb7e1fa17" alt=""
I will look at one way of dealing with these next week.
Come back next time for more ways to use Power Query!