Power Query: Riveting Results Part 1
15 December 2021
Welcome to our Power Query blog. This week, I look at an example where I plan to use parameters.
My salespeople are taking a break. This week, I am looking at some exam results:
data:image/s3,"s3://crabby-images/c6803/c6803e8bcf627843e94378caa0c67db489147087" alt=""
I will be grading the results and I will be using this example to explore parameters. I’ll start by extracting my data into Power Query, where I will create the grade column. To extract my data, I choose ‘From Table/Range’ from the ‘Get & Transform’ section of the Data tab.
data:image/s3,"s3://crabby-images/abef3/abef3fa5ef7d6242f6e45f6b5cbf3b6b71e2be49" alt=""
I have called my query Exam Results. I will begin by creating a Conditional Column from the ‘Add Column’ tab:
data:image/s3,"s3://crabby-images/d1bbc/d1bbce5706ef6d706ea2f0fa06865eecacd36bac" alt=""
I call the new column Grade, and create the grade bands for the results. Each Clause will look at whether the Result ‘is greater than’ a Value, and I will start with the highest grade.
data:image/s3,"s3://crabby-images/cb975/cb9752223a5787befe63e2031c4e2aac13cec9d9" alt=""
For now, I will be entering values, but I plan to replace this with parameters later.
data:image/s3,"s3://crabby-images/9a8e5/9a8e5b59eba4ebb07099d287d34dcd598c7bff49" alt=""
I create a Clause for each band.
data:image/s3,"s3://crabby-images/8954c/8954cc434b9a031ede43ca94804eee19e2c2a6fe" alt=""
Note that, if I miss one, I can add it later and then change the order using the menu next to each Clause.
data:image/s3,"s3://crabby-images/9e9ee/9e9ee623960a875121280764d949063aa1f386a7" alt=""
I click OK to see the new column:
data:image/s3,"s3://crabby-images/8f3a4/8f3a42fa8d3a7cbd5eb057e8c91e1737dc645859" alt=""
The M code generated for this step is as follows:
Table.AddColumn(#"Changed Type", "Grade", each if [Result] > 90 then 9 else if [Result] > 80 then 8 else if [Result] > 70 then 7 else if [Result] > 60 then 6 else if [Result] > 50 then 5 else if [Result] > 40 then 4 else if [Result] > 30 then 3 else "Ungraded")
I can change this in the Advanced Editor, which I access from the Home tab. I want to format it so that the boundaries are easier to see. I can split each step over any number of lines, a comma (,) or (as in this case) the ‘in’ statement indicates when the step is complete.
data:image/s3,"s3://crabby-images/71690/7169099a27791e0319d05959839ba3ddd7dced72" alt=""
I am now ready to create some parameters to decide the grades.
Come back next time for more ways to use Power Query!