Starting December 3, join live sessions with database experts and the Microsoft product team to learn just how easy it is to get started
Learn moreGet certified in Microsoft Fabric—for free! For a limited time, get a free DP-600 exam voucher to use by the end of 2024. Register now
Hi,
I need a column that returns all the values that appear in the "Class" column according to the "City" column, for example:
City | Class | Result |
New York | A | A,B,C |
New York | B | A,B,C |
New York | C | A,B,C |
New Jersey | A | A,B |
New Jersey | B | A,B |
Denver | A | A,B,C,D |
Denver | B | A,B,C,D |
Denver | C | A,B,C,D |
Denver | D | A,B,C,D |
Honolulu | A | A |
Anybody can help me?
tks.
Solved! Go to Solution.
If you enter that code, by itself, into the Advanced Editor, it will reproduce your data table in your original post, (at the Source step), as well as the final result (at the last step).
If you look at your own query, you will probably also see a Step named "Source" which is where your data comes from.
If your data has the same structure as the sample in your original post, all you should need to do is replace one Source with the other (in the Advanced Editor).
Use this formula:
let
Source = Excel.CurrentWorkbook(){[Name="Table2"]}[Content],
#"Added Custom" = Table.AddColumn(Source, "Custom", each Text.Combine(List.Distinct(Table.SelectRows(Source,(x)=>x[City]=[City])[Class]),","))
in
#"Added Custom"
Doesn't work,
In my case I just need create a custom colunm not a table, do you can help me?
OBS: reinforcing that this example is just a slice of the data colunm, I have a much data in colunm City and Class, I just need a custom colunm with the logic.
You can use the Table.Group method.
If you just need a single line per city:
let
Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45W8kstV4jML8pW0lFyVIrVQRFwQhdwhgt4pRYVp1aiaIILQbS5pOaVpRbBVcC5aLLOqFwXMNcjPy8/pzSnFKI7FgA=", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [City = _t, Class = _t]),
#"Changed Type" = Table.TransformColumnTypes(Source,{{"City", type text}, {"Class", type text}}),
#"Grouped Rows" = Table.Group(#"Changed Type", {"City"}, {
{"Class", each Text.Combine([Class],","), type text}})
in
#"Grouped Rows"
If you want the table expanded as you show in your question:
let
Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45W8kstV4jML8pW0lFyVIrVQRFwQhdwhgt4pRYVp1aiaIILQbS5pOaVpRbBVcC5aLLOqFwXMNcjPy8/pzSnFKI7FgA=", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [City = _t, Class = _t]),
#"Changed Type" = Table.TransformColumnTypes(Source,{{"City", type text}, {"Class", type text}}),
#"Grouped Rows" = Table.Group(#"Changed Type", {"City"}, {
{"Add Class", (t)=>Table.AddColumn(t, "Result", each Text.Combine(t[Class],",")),
type table [City=text, Class=text, Result=text]}}),
#"Expanded Add Class" = Table.ExpandTableColumn(#"Grouped Rows", "Add Class", {"Class", "Result"})
in
#"Expanded Add Class"
Hi, @ronrsnfld
In my case I just need create a custom colunm not a table, do you can help me?
OBS: reinforcing that this example is just a slice of the data colunm, I have a much data in colunm City and Class, I just need a custom colunm with the logic.
The code works on the data you presented.
You should be able to adapt one of the answers to your actual data.
And either solution should work no matter how much data you have in your City and Class columns.
If your data is truly representative, then you probably have adapted it incorrectly, but you present no information to enable troubleshooting that situation.
If your data is not truly representative, then GIGO.
@ronrsnfld
Where do I insert the code below? in a custom column or enter a step manually?
let
Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45W8kstV4jML8pW0lFyVIrVQRFwQhdwhgt4pRYVp1aiaIILQbS5pOaVpRbBVcC5aLLOqFwXMNcjPy8/pzSnFKI7FgA=", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [City = _t, Class = _t]),
#"Changed Type" = Table.TransformColumnTypes(Source,{{"City", type text}, {"Class", type text}}),
#"Grouped Rows" = Table.Group(#"Changed Type", {"City"}, {
{"Add Class", (t)=>Table.AddColumn(t, "Result", each Text.Combine(t[Class],",")),
type table [City=text, Class=text, Result=text]}}),
#"Expanded Add Class" = Table.ExpandTableColumn(#"Grouped Rows", "Add Class", {"Class", "Result"})
in
#"Expanded Add Class"
If you enter that code, by itself, into the Advanced Editor, it will reproduce your data table in your original post, (at the Source step), as well as the final result (at the last step).
If you look at your own query, you will probably also see a Step named "Source" which is where your data comes from.
If your data has the same structure as the sample in your original post, all you should need to do is replace one Source with the other (in the Advanced Editor).
Thanks its work!!
You are monster of PBI!!
Starting December 3, join live sessions with database experts and the Fabric product team to learn just how easy it is to get started.
March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount! Early Bird pricing ends December 9th.
User | Count |
---|---|
26 | |
12 | |
11 | |
11 | |
8 |