Power Query: Revision Time – Part 1
10 April 2024
Welcome to our Power Query blog. Today, I begin to create a refreshable revision timetable by extracting the inputs.
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/1cfb4/1cfb4be0948c9acfb5dd883de3c466361b613bd2" alt=""
Let’s have a look at what I put together. I started off with the inputs. 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/e6fc4/e6fc43fea1426865746be9099f3153c6ec445476" 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/f3855/f3855ca19d07bab2b5feadf5297b243837797d11" 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!).
Before I extract my data, I am going to convert it into two [2] Tables, which will allow me to name the Tables before I extract them. I may use ‘Convert to Table’ from the Insert tab, or CTRL + T. In each case, I check the regions and indicate that my Tables will have headers.
data:image/s3,"s3://crabby-images/c7bba/c7bba556d82ad9259470d653033852554417f311" alt=""
I name the Tables Subjects and Availability respectively.
Next, I click somewhere in the Subjects table, and on the ‘Get & Transform Data’ section of the Data tab, I choose to extract data ‘From Table/Range’. I use the icon indicated in my version of Excel: yours might look slightly different.
data:image/s3,"s3://crabby-images/7b57b/7b57b1cf3638dd3d83a11fae757d002422e9fe08" alt=""
In the Power Query editor, I see the query Subjects. Note that another benefit of converting the data to a Table before I extracted it, is that it is extracted as a Table and not a list.
data:image/s3,"s3://crabby-images/0da82/0da82d8dbfece7956a3d98ab2932451b52e56e90" alt=""
I could go back to the workbook and repeat this process for the other Table, but instead I will take a duplicate copy of the Subjects query:
data:image/s3,"s3://crabby-images/2f9e0/2f9e09c22c6a23888b0cb43de7c42ab6c5e7cef2" alt=""
I call the new query Availability:
data:image/s3,"s3://crabby-images/04653/0465351c85e4023c1c2d02dacbf29b6a9975a3d2" alt=""
I delete the ‘Changed Type’ step, and look at the Source step:
data:image/s3,"s3://crabby-images/b6c4e/b6c4e757958657d1b3f021eb6684c8155e7651fe" alt=""
The M code is:
= Excel.CurrentWorkbook(){[Name="Subjects"]}[Content]
If I change the Name parameter to ‘Availability’, I will pick up the second Table:
data:image/s3,"s3://crabby-images/616a1/616a1869dd768f0578399f01288e21b34a90fd73" alt=""
Since I have chosen to detect types in the settings, another ‘Changed Type’ step has been generated, but I clearly need to change Column1:
data:image/s3,"s3://crabby-images/da42b/da42b4ecf22690e6ac23740cf4ca62decf6f3621" alt=""
Since I know this is a time, I change the data type to time by clicking on the number icon in the heading:
data:image/s3,"s3://crabby-images/5bcef/5bcefd4d45eca3dab4cc8125424859420c16d9f2" alt=""
I am prompted to include this transformation in the existing ‘Changed Type’ step:
data:image/s3,"s3://crabby-images/41664/416645a35bae547611bbcf834419c44cf7a9293e" alt=""
I click ‘Replace current’ and rename Column1. My data is ready to be transformed next week:
data:image/s3,"s3://crabby-images/497b0/497b056ab6418339f2d85a750314e3026b619ad3" alt=""
Come back next time for more ways to use Power Query!