Power BI is turning 10! Tune in for a special live episode on July 24 with behind-the-scenes stories, product evolution highlights, and a sneak peek at what’s in store for the future.
Save the dateEnhance your career with this limited time 50% discount on Fabric and Power BI exams. Ends August 31st. Request your voucher.
There are two columns, CLASS and DOC_TEXT. Where rows under DOC_TEXT contain (not equal to) the word "sale", values under column CLASS must change to "Direct Sale". I used TransformColumns and I believe I have everything correct. No errors occur when applying this M code in the advanced editor and closing out. However, in the "edit query" page, after this step is applied, the entire CLASS column - all rows now say "error" .. I can't figure out what I'm doing wrong. Should I be using the ReplaceValues function?
My code (previous step is called Replaced Value1) :
#"Updated Column" = Table.TransformColumns(#"Replaced Value1", {{"CLASS", each
if Text.Contains([DOC_TEXT], "sale", Comparer.OrdinalIgnoreCase) then "Direct Sale"
else [CLASS], type text}})
Solved! Go to Solution.
Hi @Ak14pbi, check this:
Output
If you want to seach for "sale" case insensitive, replace Comparer.Ordinal with Comparer.OrdinalIgnoreCase
let
Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WclTSUSrOz01VKEmtKFGK1YlWcgKKJCYlKxQn5qQqpKalgwWdQcqAAmCOC5CTX5KRWgTVFAsA", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [CLASS = _t, DOC_TEXT = _t]),
ReplacedClass = Table.ReplaceValue(Source,
each Text.Contains([DOC_TEXT], "sale", Comparer.Ordinal),
each "Direct Sale",
(x,y,z)=> if y then z else x,
{"CLASS"} )
in
ReplacedClass
Hi @Ak14pbi,
Thanks for reaching out to the Microsoft fabric community forum.
It looks like you are trying to transfrom a column when there's a certain value (sale) in it. As @Omid_Motamedise, @dufoq3 and @ZhangKun provided solutions from their side. Please go through the solutions provided and mark the helpful reply as solution.
I would also take a moment to thank @Omid_Motamedise, @dufoq3 and @ZhangKun, for actively participating in the community forum and for the solutions you’ve been sharing in the community forum. Your contributions make a real difference.
If I misunderstand your needs or you still have problems on it, please feel free to let us know.
Best Regards,
Hammad.
Community Support Team
If this post helps then please mark it as a solution, so that other members find it more quickly.
Thank you.
In transforming the column, you are not allwed to refer to other column like [CLASS], so as mentioned use replace command or add a new column, or merge the both column.
Thank you so much!
Hi @Ak14pbi, check this:
Output
If you want to seach for "sale" case insensitive, replace Comparer.Ordinal with Comparer.OrdinalIgnoreCase
let
Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WclTSUSrOz01VKEmtKFGK1YlWcgKKJCYlKxQn5qQqpKalgwWdQcqAAmCOC5CTX5KRWgTVFAsA", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [CLASS = _t, DOC_TEXT = _t]),
ReplacedClass = Table.ReplaceValue(Source,
each Text.Contains([DOC_TEXT], "sale", Comparer.Ordinal),
each "Direct Sale",
(x,y,z)=> if y then z else x,
{"CLASS"} )
in
ReplacedClass
Thank you so much for your help!
Yes, you should use ReplaceValues.
One very important difference is that TransformColumns cannot access other columns, but ReplaceValue can do it.
Thank you for your help!