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
LucTP
Frequent Visitor

Replace values with more text contains

Hi Everyone!

How to Replace values with a text, where some text X contains in column A then Replate Column B values Y else value column A
Example:

 

ADDRESSCOUNTRY
EDIFICIO IBERCONSA-FRIGALSA LA, RIOUXA S/N - TEIS VIGO-PONTEVEDRA, 36216 SPAIN, PT36216 SPAIN
AVDA. EL CHOPO 4, 39311 SANTIAGO DE CARTES, CANTABRIA, SPAIN, ESSPAIN
AVDA. EL CHOPO 4, 39311 SANTIAGO DE CARTES, CANTABRIA, SPAIN, ESSPAIN

 

Result

 

ADDRESSCOUNTRY
EDIFICIO IBERCONSA-FRIGALSA LA, RIOUXA S/N - TEIS VIGO-PONTEVEDRA, 36216 SPAIN, PTSPAIN
AVDA. EL CHOPO 4, 39311 SANTIAGO DE CARTES, CANTABRIA, SPAIN, ESSPAIN
AVDA. EL CHOPO 4, 39311 SANTIAGO DE CARTES, CANTABRIA, SPAIN, ESSPAIN


MY code :  option text X is list not working

 

 

 

Table.ReplaceValue(#"Replaced Value8",each [COUNTRY], each
            if Text.Contains([ADDRESS],{", PT",", ES"}) then "SPAIN" else
                [COUNTRY], Replacer.ReplaceValue, {"COUNTRY"})

 

How to fix it 

 

Thanks & Regards,

LucTP

 

2 ACCEPTED SOLUTIONS
AlienSx
Super User
Super User

hello, @LucTP 

    Table.ReplaceValue(
        #"Replaced Value8", 
        each List.Contains(
            {", PT",", ES"},
            [ADDRESS],
            (x, y) => Text.Contains(y, x)
        ),
        null, 
        (v, o, n) => if o then "SPAIN" else v,
        {"COUNTRY"}
    )

View solution in original post

dufoq3
Super User
Super User

Hi @LucTP, anoteher 2 versions of code

 

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("tYxBCsIwEEWv8sk6VdJKweWYTutgyIQkBqH0/tcwggsv4OrD4/2374YXWcWLQm6cvcZCw5plo1AIgSyy6PNFKOeIAZWloMmmQ9JYufGSuzLNo5tREkm0SNVY80PMYXdDbaETOMDfNSku/XOdnEOhWIU2xcLwlCsX2zdWumXp4W+SS0/+Kdat2hncOH140EYPIXMcbw==", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [ADDRESS = _t, COUNTRY = _t]),
    ReplaceCountry_v1_Contains = Table.ReplaceValue(Source,
        each List.ContainsAny(Text.SplitAny([ADDRESS], " ,"), {"PT", "ES"}),
        each "SPAIN",
        (x,y,z)=> if y then z else x,
        {"COUNTRY"} ),
    ReplaceCountry_v2_EndsWith = Table.ReplaceValue(Source,
        each List.ContainsAny(List.LastN(Text.SplitAny([ADDRESS], " ,"), 1), {"PT", "ES"}),
        each "SPAIN",
        (x,y,z)=> if y then z else x,
        {"COUNTRY"} )
in
    ReplaceCountry_v2_EndsWith

Note: Check this link to learn how to use my query.
Check this link if you don't know how to provide sample data.

View solution in original post

2 REPLIES 2
dufoq3
Super User
Super User

Hi @LucTP, anoteher 2 versions of code

 

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("tYxBCsIwEEWv8sk6VdJKweWYTutgyIQkBqH0/tcwggsv4OrD4/2374YXWcWLQm6cvcZCw5plo1AIgSyy6PNFKOeIAZWloMmmQ9JYufGSuzLNo5tREkm0SNVY80PMYXdDbaETOMDfNSku/XOdnEOhWIU2xcLwlCsX2zdWumXp4W+SS0/+Kdat2hncOH140EYPIXMcbw==", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [ADDRESS = _t, COUNTRY = _t]),
    ReplaceCountry_v1_Contains = Table.ReplaceValue(Source,
        each List.ContainsAny(Text.SplitAny([ADDRESS], " ,"), {"PT", "ES"}),
        each "SPAIN",
        (x,y,z)=> if y then z else x,
        {"COUNTRY"} ),
    ReplaceCountry_v2_EndsWith = Table.ReplaceValue(Source,
        each List.ContainsAny(List.LastN(Text.SplitAny([ADDRESS], " ,"), 1), {"PT", "ES"}),
        each "SPAIN",
        (x,y,z)=> if y then z else x,
        {"COUNTRY"} )
in
    ReplaceCountry_v2_EndsWith

Note: Check this link to learn how to use my query.
Check this link if you don't know how to provide sample data.

AlienSx
Super User
Super User

hello, @LucTP 

    Table.ReplaceValue(
        #"Replaced Value8", 
        each List.Contains(
            {", PT",", ES"},
            [ADDRESS],
            (x, y) => Text.Contains(y, x)
        ),
        null, 
        (v, o, n) => if o then "SPAIN" else v,
        {"COUNTRY"}
    )

Helpful resources

Announcements
PBI_APRIL_CAROUSEL1

Power BI Monthly Update - April 2024

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

Top Solution Authors
Top Kudoed Authors