Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Earn a 50% discount on the DP-600 certification exam by completing the Fabric 30 Days to Learn It challenge.

Reply
amay
New Member

Power Query change column text based on a condition

Hello,

I need to replace values in power query based on a condition:

If Column B contains 31456 or 42987 or 45028 change Column A to "Direct sales" otherwise leave column A as is.  I've tried every example of code I can find on here and none work.

1 ACCEPTED SOLUTION
jbwtp
Memorable Member
Memorable Member

Hi @amay,

 

if you want to actually replace  rather then add column and then delete/rename (which I think just as equally Ok performance-wise), you can try this code:

 

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("LcfLFYAgDATAXvbMARJQOPq3h7z034a6Zm5jhgUJWmqb4Mmwvqsy+sxt31qWzu2xwR3/NHNnrHBXTLg7pnB/AA==", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [A = _t, B = _t]),
    #"Changed Type" = Table.TransformColumnTypes(Source,{{"A", type text}, {"B", Int64.Type}}),
    #"Replaced Value" = Table.ReplaceValue(#"Changed Type",each [B], "Direct Sales", (x, y, z)=> if List.Contains({31456, 42987, 45028}, y) then z else x,{"A"})
in
    #"Replaced Value"

 

 

Cheers,

John

 

View solution in original post

2 REPLIES 2
jbwtp
Memorable Member
Memorable Member

Hi @amay,

 

if you want to actually replace  rather then add column and then delete/rename (which I think just as equally Ok performance-wise), you can try this code:

 

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("LcfLFYAgDATAXvbMARJQOPq3h7z034a6Zm5jhgUJWmqb4Mmwvqsy+sxt31qWzu2xwR3/NHNnrHBXTLg7pnB/AA==", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [A = _t, B = _t]),
    #"Changed Type" = Table.TransformColumnTypes(Source,{{"A", type text}, {"B", Int64.Type}}),
    #"Replaced Value" = Table.ReplaceValue(#"Changed Type",each [B], "Direct Sales", (x, y, z)=> if List.Contains({31456, 42987, 45028}, y) then z else x,{"A"})
in
    #"Replaced Value"

 

 

Cheers,

John

 

sudhav
Helper V
Helper V

you can try this. add a conditional column

sudhav_0-1676482943388.png

sudhav_1-1676483086522.png

refer two pics.

If I answered your question, please accept it as solution and give kudos.

Helpful resources

Announcements
LearnSurvey

Fabric certifications survey

Certification feedback opportunity for the community.

PBI_APRIL_CAROUSEL1

Power BI Monthly Update - April 2024

Check out the April 2024 Power BI update to learn about new features.

April Fabric Community Update

Fabric Community Update - April 2024

Find out what's new and trending in the Fabric Community.

Top Solution Authors
Top Kudoed Authors