Power Query: Selective Staffing Part 4
17 November 2021
Welcome to our Power Query blog. This week, I revisit my first inclusion examples to find solutions that involve exclusion.
I have looked at two examples over the last few weeks where I included data based upon a list of values. I will look at both examples to see how I would have excluded the data instead.
The first example was in Selective Staffing Part 1 where I had allocated salespeople:
data:image/s3,"s3://crabby-images/fcf26/fcf26336276a8fd3772b4dcc9d4af50da8de7418" alt=""
I needed to produce a version of this table only including the available salespeople:
data:image/s3,"s3://crabby-images/d441c/d441cffafc53929082717e3d048aba9016b4ef89" alt=""
I created a new table which showed only the included salespeople for each area:
data:image/s3,"s3://crabby-images/4e882/4e882778bb615366e471592e968abb81e61664a6" alt=""
However, I could have the situation where some of the salespeople have been booked for a conference, and I need to exclude them from my allocations.
data:image/s3,"s3://crabby-images/d5a3d/d5a3d33f3d6528825bd94d04a039dae0b5a8d0e2" alt=""
The Excel Tables for this example are Staffing_Exclude and Selection_Exclude. I create a new query Selection Exclude which is similar to the query Selection I used in Selective Staffing Part 2. Selection extracted the included staff table Selection and converted it to a list. This query extracts Selection_Exclude.
data:image/s3,"s3://crabby-images/ed97f/ed97fc11d54af7a0df1c41e4e07e0114a8ef5169" alt=""
You will recall that there were two main issues to solve when solving the inclusion problem. I needed to work out which values to keep and then remove spaces in the table. Only the first issue is affected by excluding instead of including, so I will make a duplicate of the query I finished in Selective Staffing Part 2, which is called Staffing. The first step I need to change is the Source step:
data:image/s3,"s3://crabby-images/e4b91/e4b91c3484dce3479344039d9a12634cb3fddd96" alt=""
Currently, this is extracting data from the Excel table Staffing:
= Excel.CurrentWorkbook(){[Name="Staffing"]}[Content]
I can change this to Staffing_Exclude, to point at the new table.
= Excel.CurrentWorkbook(){[Name="Staffing_Exclude"]}[Content]
To save this change, I press ENTER or use the tick next to the formula bar.
Having changed the Source, I need to change any steps that selected data based upon the included list.
data:image/s3,"s3://crabby-images/9a25e/9a25e26723fdf9137d90691a019d525fc8503f2b" alt=""
The only steps that will be affected are the ‘Added Custom’ steps, as the remainder of the query is dealing with blank values.
If I look at the first ‘Added Custom’ step using the gear icon, I can see the M code I used:
data:image/s3,"s3://crabby-images/06afe/06afe7a5bd014569fe8f484371c74a83f7e7aff4" alt=""
The M code is:
= if List.ContainsAny(Selection, {[#"Marketing "]}) then [#"Marketing "] else null
Selection is the included staff table; I need to change this to use Selection_Exclude.
= if List.ContainsAny(Selection_Exclude, {[#"Marketing "]}) then [#"Marketing "] else null
I also need to reverse the logic, as I need to include data which is not on the list.
= if List.ContainsAny(Selection_Exclude, {[#"Marketing "]}) then null else [#"Marketing "]
I need to make these changes to all the ‘Custom Column’ steps.
data:image/s3,"s3://crabby-images/91a72/91a725517df9ba62650f5fa75302577d20a514b0" alt=""
The salespeople in the excluded list have now been removed from the table, and the remaining steps will reorganise the data to remove the blank values. I rename the query Staffing Exclude.
data:image/s3,"s3://crabby-images/98296/98296bc7e3c084a80240e1eff465474497bf50d8" alt=""
When I ‘Close & Load’ the data, I have only the salespeople that are not excluded:
data:image/s3,"s3://crabby-images/ef3fc/ef3fc580d16853b9f163e3cfd45c2b486e05babc" alt=""
Next time I will look at how to exclude data in my second example…
Come back next time for more ways to use Power Query!