Power Query: Simply Conditional
19 August 2020
Welcome to our Power Query blog. This week I look at a method to conditionally replace values efficiently.
I have the following tent data:
data:image/s3,"s3://crabby-images/235ad/235ad6b3eda74c308e344662b2413efb9411c427" alt=""
I want to add a prefix to the data in my Awning column, which is dependent on the value in that column, viz.
- Blank: N/A
- Standard or Dining: Fixed
- Budget: (No prefix)
- Package or Kids: Variable.
I begin by extracting my data to Power Query using ‘From Table’ on the ‘New Query’ section of the ‘Get & Transform’ section on the Data tab.
data:image/s3,"s3://crabby-images/de235/de235a5f05e87cbf664421537cab5af0a97ee80e" alt=""
I accept the defaults.
data:image/s3,"s3://crabby-images/0782e/0782e8d437f54c0a1875f8f352e171352dc0f10b" alt=""
I could use a custom column to achieve my required result:
data:image/s3,"s3://crabby-images/2d87f/2d87ffb92733bb54d6b49a08087ac19ba7feee2b" alt=""
The M code I have used is:
if [Awning] is null then "N/A "
else if [Awning] = "Package" or [Awning]= "Kids" then "Variable " & [Awning]
else if [Awning] = "Standard" or [Awning] = "Dining" then "Fixed " & [Awning]
else [Awning]
When I click ‘OK’, I get my new column:
data:image/s3,"s3://crabby-images/306a6/306a674f54c96f986fbfe79f32b8914ea29d2f76" alt=""
Taking the ‘if’ statement I used, I can do this another way, by using 'Replace values’.
data:image/s3,"s3://crabby-images/96ef9/96ef9b8ed7ede6e235258b898303f4b96c3bbc3a" alt=""
I am going to start by creating a simple ‘Replace values’ statement by replacing null with ‘N/A’:
data:image/s3,"s3://crabby-images/b3cc4/b3cc4d667a075eddd3bb14773fd1db8e77982311" alt=""
When I click ‘OK’, the null values are replaced.
data:image/s3,"s3://crabby-images/2d4c6/2d4c673de2b072f4c41f1c192b1a3742336fac9e" alt=""
More importantly, the M code for this step has been generated:
= Table.ReplaceValue(#"Changed Type",null,"N/A",Replacer.ReplaceValue,{"Awning"})
I need to change this so that I can apply a change to every row, so instead of null, I am going to use ‘each [Awning]’:
= Table.ReplaceValue(#"Changed Type",each [Awning], "N/A",Replacer.ReplaceValue,{"Awning"})
I am now going to replace ‘N/A’ with the ‘if’ statement I used earlier, prefixed by ‘each’ as I am applying it to each row.
= Table.ReplaceValue(#"Changed Type",each [Awning], each if [Awning] is null then "N/A "
else if [Awning] = "Package" or [Awning]= "Kids" then "Variable " & [Awning]
else if [Awning] = "Standard" or [Awning] = "Dining" then "Fixed " & [Awning]
else [Awning]
,Replacer.ReplaceValue,{"Awning"})
data:image/s3,"s3://crabby-images/7874d/7874dde630f2858b8da472fa6ab1a08596e57da5" alt=""
When I click the tick next to my amended step, I can see the results.
data:image/s3,"s3://crabby-images/a1a9c/a1a9c5076ae94991f6c94491ad6e9f7f79ef5451" alt=""
I have applied a conditional change in my column without the need for an extra column.
Come back next time for more ways to use Power Query!