cancel
Showing results for 
Search instead for 
Did you mean: 

Fabric is Generally Available. Browse Fabric Presentations. Work towards your Fabric certification with the Cloud Skills Challenge.

Reply
Anonymous
Not applicable

Replacing values in multiple columns based on condition in Power Query

Hello,

 

I have a table like this:

Date    plan        unplan        internal        external        production         day flag    
1/1/2020    0050706000Production Day
1/2/2020    00000Non-Production Day
1/3/2020    001002001300Down Day
1/4/2020    0030805000Production Day
1/5/2020    001201501000Down Day
1/6/2020    00000Non-Production Day
1/7/2020    00000Non-Production Day

 

if [day flag] = "Down Day" then replace [plan], [unplan], [internal] and [external] columns with null, else keep original values.

The result like this:

Date    plan        unplan        internal        external         production    day flag
1/1/2020    0050706000Production Day
1/2/2020    00000Non-Production Day
1/3/2020    nullnullnullnull1300Down Day
1/4/2020    0030805000Production Day
1/5/2020    nullnullnullnull1000Down Day
1/6/2020    00000Non-Production Day
1/7/2020    00000Non-Production Day

 

I use code:

#"Replaced Value1" = Table.ReplaceValue(Source, each [plan], each if [day flag] = "Down Day" then null else [plan],Replacer.ReplaceValue,{"plan"}),
#"Replaced Value2" = Table.ReplaceValue(#"Replaced Value1",each [unplan], each if [day flag] = "Down Day" then null else [unplan], Replacer.ReplaceValue,{"unplan"}),
#"Replaced Value3" = ...

#"Replaced Value4" = ...

 

As you see, I have to repeat same logic 4 times for replace values of [plan], [unplan], [internal] and [external] columns. Actually, in my table, there are 20 columns need do that. I don't want to repeat this logic 20 times.

 

I was wondering if any better solution for my situation?

 

Thanks!

2 ACCEPTED SOLUTIONS
ziying35
Impactful Individual
Impactful Individual

Hi, @Anonymous 

Based on the simulated data source and the data processing logic you provided, write the query code like this:

= Table.ReplaceValue(Source, each [day flag]="Down Day", null, (x,y,z)=> if y then z else x, List.Range(Table.ColumnNames(Source),1,4))

If my code solves your problem, mark it as a solution

View solution in original post

v-alq-msft
Community Support
Community Support

Hi, @Anonymous 

 

As what is suggested by @ziying35 , I created data to reproduce your scenario. The pbix file is attached in the end.

Table:

d1.png

 

You may insert a new step as below. On your side, you may add all corresponding columns in {"plan","unplan","internal","external",...}.

= Table.ReplaceValue(Source, each [day flag]="Down Day", null, (x,y,z)=> if y then z else x, List.Select(Table.ColumnNames(#"Changed Type"),
each  List.Contains( {"plan","unplan","internal","external"},_)
)
)

 

Result:

d2.png

 

Best Regards

Allan

 

If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.

View solution in original post

11 REPLIES 11
Rickmaurinus
Helper V
Helper V

Another way to do it, is the unpivot your columns, and then on the newly created column apply a conditional replace operation. 

 

 

= Table.ReplaceValue(
     #"Changed Type",
     each [Value],
     each if [day flag] = "Down Day" then null else [Value],
     Replacer.ReplaceValue,{"Value"}
 )

 

 

You can find the details on the conditional replace right here: 

https://gorilla.bi/power-query/replace-values/#conditionally-replace-values

 

--------------------------------------------------

@ me in replies or I'll lose your thread

 

Master Power Query M? -> https://powerquery.how

Read in-depth articles? -> BI Gorilla

Youtube Channel: BI Gorilla

 

If this post helps, then please consider accepting it as the solution to help other members find it more quickly.

v-alq-msft
Community Support
Community Support

Hi, @Anonymous 

 

As what is suggested by @ziying35 , I created data to reproduce your scenario. The pbix file is attached in the end.

Table:

d1.png

 

You may insert a new step as below. On your side, you may add all corresponding columns in {"plan","unplan","internal","external",...}.

= Table.ReplaceValue(Source, each [day flag]="Down Day", null, (x,y,z)=> if y then z else x, List.Select(Table.ColumnNames(#"Changed Type"),
each  List.Contains( {"plan","unplan","internal","external"},_)
)
)

 

Result:

d2.png

 

Best Regards

Allan

 

If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.

Anonymous
Not applicable

Thank you very much! Your demostration is really very helpful for understanding the code. It works on my end!

ziying35
Impactful Individual
Impactful Individual

Hi, @Anonymous 

Based on the simulated data source and the data processing logic you provided, write the query code like this:

= Table.ReplaceValue(Source, each [day flag]="Down Day", null, (x,y,z)=> if y then z else x, List.Range(Table.ColumnNames(Source),1,4))

If my code solves your problem, mark it as a solution

Hey ziying35.

 

I included your solution in my blogpost at https://gorilla.bi/power-query/replace-values/

However, I'm accustomed to working with Replacer.ReplaceValues and Replacer.ReplaceText. I don't fully understand your example. 

Can you elaborate on the inner workings of : 

(x,y,z)=> if y then z else x?

 

Warm regards,

Rick

Simple understanding: the second parameter of the function Table.ReplaceValue is represented by y, the third parameter is represented by z, and the replaced element itself is represented by x

Hi ziying,

 

Thanks for adding the clarification. I could imagine in my head that happens. I'm just stumbled by how you thought of doing this, please help me understand. 

 

No where does it say that Y represents the Table function, or that the third parameters should be the Z or what X should do. 

 

If I can ask

1. How did you come up with this in the first place? Is there any documentation on this? 

2. In theory, you could have replaced the function letters with any other letter, correct? 

 

Best,

Rick

1. this use, I also happened to see in other places, I can not remember the place,.
2. Yes, there is nothing wrong, you can use any other letters instead

You can replace it with any string you want.

(original,logiccheck,alternative)=> if logiccheck then alternative else original

 

Yes, the documentation is a bit sparse on this.  Here's a slight hint:

Replacer.ReplaceValue - PowerQuery M | Microsoft Docs

It's misleading, but at least it mentions parameters 🙂

 

I have a suspicion that this approach can be used for other M functions as well.  Didn't have time to test it yet.

 

x = original value

y = match condition  (true or false)

z = replacement value

edhans
Super User
Super User

You can include multiple columns in the list. This is a text replacement. Just add more columns in the list brackets {}

Table.ReplaceValue(#"Filtered Rows","a","g",Replacer.ReplaceText,{"Stock Item", "Color", "Selling Package"})

 



Did I answer your question? Mark my post as a solution!
Did my answers help arrive at a solution? Give it a kudos by clicking the Thumbs Up!

DAX is for Analysis. Power Query is for Data Modeling


Proud to be a Super User!

MCSA: BI Reporting

Helpful resources

Announcements
PBI November 2023 Update Carousel

Power BI Monthly Update - November 2023

Check out the November 2023 Power BI update to learn about new features.

Power BI Fabric Summit Carousel

The largest Power BI and Fabric virtual conference

130+ sessions, 130+ speakers, Product managers, MVPs, and experts. All about Power BI and Fabric. Attend online or watch the recordings.

Top Solution Authors