Join us at FabCon Atlanta from March 16 - 20, 2026, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM.
Register now!Vote for your favorite vizzies from the Power BI Dataviz World Championship submissions. Vote now!
Hello,
I have a table as per below:
| Main | Category | Category 2 | Final |
| A | Apples=Pears | Pears,Raisin,Apple | Raisin |
| B | Red | Yellow,Green,Red | Yellow,Green |
| C | Seven=Five=Six | One,Two,Three,Four,Seven | One,Two,Three,Four |
The Final table is what I need to achieve, so I need to substract each string in "Category" (between "=") from the Category 2 if they are present.
Can you please h elp me? I am at a loss for ideas.
Thanks!
Kind regards
Valeria
Solved! Go to Solution.
Hi @ValeriaBreve, you made a mistake probably, so I've edited your sample data a bit
Result
let
Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("HYq7CoAwFEP/5c75hQ4q6Kioi5QOggELpZWKj8/32iUh58RaqQRSHUegGbjmU1dpjKs/fURR4mClVjVy01wYQnrQZTLiR79uVEy8GU3rb5rJvwr6SMxPwrzrF226MspHnPsA", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [Main = _t, Category = _t, #"Category 2" = _t]),
Ad_Final = Table.AddColumn(Source, "Final", each
[ a = Text.Split([Category], "="),
b = Splitter.SplitTextByAnyDelimiter(a)([Category 2]),
c = Text.Combine(List.Select(List.Transform(b, (x)=> Text.Trim(x, {" ", ","})), (y)=> not List.Contains({"", null},y)))
][c], type text)
in
Ad_Final
Hi @ValeriaBreve, you made a mistake probably, so I've edited your sample data a bit
Result
let
Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("HYq7CoAwFEP/5c75hQ4q6Kioi5QOggELpZWKj8/32iUh58RaqQRSHUegGbjmU1dpjKs/fURR4mClVjVy01wYQnrQZTLiR79uVEy8GU3rb5rJvwr6SMxPwrzrF226MspHnPsA", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [Main = _t, Category = _t, #"Category 2" = _t]),
Ad_Final = Table.AddColumn(Source, "Final", each
[ a = Text.Split([Category], "="),
b = Splitter.SplitTextByAnyDelimiter(a)([Category 2]),
c = Text.Combine(List.Select(List.Transform(b, (x)=> Text.Trim(x, {" ", ","})), (y)=> not List.Contains({"", null},y)))
][c], type text)
in
Ad_Final
Thanks @dufoq3 ! Yes you are right I made a spelling msitake in the data - sorry about that! And your solution works very well. Thanks! 🙂
OK I think I got there...
= Table.AddColumn(#"Changed Type", "No_Match",
each
List.RemoveMatchingItems(
Text.Split([Category 2],","),
Text.Split([Category],"=")
)
)
But I am opne to any other suggestions 🙂
Thanks!
Vote for your favorite vizzies from the Power BI World Championship submissions!
If you love stickers, then you will definitely want to check out our Community Sticker Challenge!
Check out the January 2026 Power BI update to learn about new features.
| User | Count |
|---|---|
| 11 | |
| 10 | |
| 6 | |
| 6 | |
| 6 |