Reply
avatar user
Anonymous
Not applicable
Partially syndicated - Outbound

Transform columns into rows

Hi everyone, all good?

I'm trying to transform columns into rows using Power Query for the following example table:

(actual table)

FatherID---ABAB
Y10201113
W805057

 

I need to resume columns A,B (and more) into a single column called ID, for example: 

(Expected table)

FatherID--ID--Value1-Value2-
YA1011
YB2013
WA805
WB507

 

I have tried to use the feature "Transform Columns into Rows", but I'm stuck with the following result:

FatherID--ID1--Value1-ID2-Value2-
YA10A11
YA10B13
YB20A11
YB20B13
WA80A5
WA80B7
WB50A5
WB50B7

 

The solution seems to be very simple but I can't help myself resolving it, could you guys help me with this?

1 ACCEPTED SOLUTION
tackytechtom
Super User
Super User

Syndicated - Outbound

Hi @Anonymous ,

 

How about this? Note, I could not name multiple columns with the same name though. 

 

Before:

tackytechtom_0-1689209832399.png

 

After:

tackytechtom_1-1689209892927.png

 

 

The trick here was to use unpivot columns 🙂 

Here the code in Power Query M that you can paste into the advanced editor (if you do not know, how to exactly do this, please check out this quick walkthrough)

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WilTSUTI0ABJGIMLQEEQYK8XqRCuFA5kWIEFTMAHE5kqxsQA=", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [FatherID = _t, A = _t, B = _t, A.1 = _t, B.1 = _t]),
    #"Unpivoted Columns" = Table.UnpivotOtherColumns(Source, {"FatherID", "A.1", "B.1"}, "Attribute", "Value1"),
    #"Unpivoted Columns1" = Table.UnpivotOtherColumns(Source, {"FatherID", "A", "B"}, "Attribute", "Value2"),
    #"Split Column by Delimiter" = Table.SplitColumn(#"Unpivoted Columns1", "Attribute", Splitter.SplitTextByDelimiter(".", QuoteStyle.Csv), {"Attribute", "Attribute.2"}),
    #"Merged Queries" = Table.NestedJoin(#"Unpivoted Columns", {"FatherID", "Attribute"}, #"Split Column by Delimiter", {"FatherID", "Attribute"}, "Split Column by Delimiter", JoinKind.LeftOuter),
    #"Expanded Split Column by Delimiter" = Table.ExpandTableColumn(#"Merged Queries", "Split Column by Delimiter", {"Value2"}, {"Value2"}),
    #"Removed Columns" = Table.RemoveColumns(#"Expanded Split Column by Delimiter",{"A.1", "B.1"})
in
    #"Removed Columns"

 

Let me know if this helps 🙂

 

/Tom
https://www.tackytech.blog/
https://www.instagram.com/tackytechtom/ 



Did I answer your question➡️ Please, mark my post as a solution ✔️

Also happily accepting Kudos 🙂

Feel free to connect with me on LinkedIn! linkedIn

#proudtobeasuperuser 

View solution in original post

4 REPLIES 4
slorin
Super User
Super User

Syndicated - Outbound

Hi,

 

Another solution with Table.Group

 

let
Source = Your_Source,
ID = List.Range(Table.ColumnNames(Source), 1, (Table.ColumnCount(Source)-1)/2 ),
Col_Names = {"ID", "Value1", "Value2"},
Group = Table.Group(Source, {"FatherID"},
{{"Data", each Table.FromColumns( {ID} & List.Split(List.Skip(Table.ToRows(_){0}), List.Count(ID)), Col_Names)}}),
Expand = Table.ExpandTableColumn(Group, "Data", Col_Names, Col_Names)
in
Expand

 

Stéphane 

AlienSx
Super User
Super User

Syndicated - Outbound

Hi, @Anonymous a weird but names independent attempt

let
    // your_table with FartherID etc. as first row (not headers!) 
    Source = your_table,
    columns = Table.ToColumns(Source),
    data = List.Buffer(List.Skip(columns)),
    c_rows = Table.RowCount(Source) - 1,
    f_id = List.Buffer(List.Skip(columns{0})),
    v_id = List.Buffer(List.Distinct(List.Skip(Record.FieldValues(Source{0})))),
    collect = 
        List.Transform(
            v_id,
            (x) => {f_id} & {List.Repeat({x}, c_rows)} & List.Skip(List.Zip(List.Select(data, (w) => List.First(w) = x)))
        ),
    c_values = {1..List.Count(collect{0}) - 2},
    val_names = List.Transform(c_values, (x) => "Value" & Text.From(x)),
    tbl = Table.Combine(List.Transform(collect, (x) => Table.FromColumns(x, {"FatherID", "ID"} & val_names)))
in
    tbl
tackytechtom
Super User
Super User

Syndicated - Outbound

Hi @Anonymous ,

 

How about this? Note, I could not name multiple columns with the same name though. 

 

Before:

tackytechtom_0-1689209832399.png

 

After:

tackytechtom_1-1689209892927.png

 

 

The trick here was to use unpivot columns 🙂 

Here the code in Power Query M that you can paste into the advanced editor (if you do not know, how to exactly do this, please check out this quick walkthrough)

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WilTSUTI0ABJGIMLQEEQYK8XqRCuFA5kWIEFTMAHE5kqxsQA=", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [FatherID = _t, A = _t, B = _t, A.1 = _t, B.1 = _t]),
    #"Unpivoted Columns" = Table.UnpivotOtherColumns(Source, {"FatherID", "A.1", "B.1"}, "Attribute", "Value1"),
    #"Unpivoted Columns1" = Table.UnpivotOtherColumns(Source, {"FatherID", "A", "B"}, "Attribute", "Value2"),
    #"Split Column by Delimiter" = Table.SplitColumn(#"Unpivoted Columns1", "Attribute", Splitter.SplitTextByDelimiter(".", QuoteStyle.Csv), {"Attribute", "Attribute.2"}),
    #"Merged Queries" = Table.NestedJoin(#"Unpivoted Columns", {"FatherID", "Attribute"}, #"Split Column by Delimiter", {"FatherID", "Attribute"}, "Split Column by Delimiter", JoinKind.LeftOuter),
    #"Expanded Split Column by Delimiter" = Table.ExpandTableColumn(#"Merged Queries", "Split Column by Delimiter", {"Value2"}, {"Value2"}),
    #"Removed Columns" = Table.RemoveColumns(#"Expanded Split Column by Delimiter",{"A.1", "B.1"})
in
    #"Removed Columns"

 

Let me know if this helps 🙂

 

/Tom
https://www.tackytech.blog/
https://www.instagram.com/tackytechtom/ 



Did I answer your question➡️ Please, mark my post as a solution ✔️

Also happily accepting Kudos 🙂

Feel free to connect with me on LinkedIn! linkedIn

#proudtobeasuperuser 

avatar user
Anonymous
Not applicable

Syndicated - Outbound

Hey! I got it here, the trick I see was using unpivot columns separately, them merging both new columns, that was a very good trick hahaha!

avatar user

Helpful resources

Announcements
March PBI video - carousel

Power BI Monthly Update - March 2025

Check out the March 2025 Power BI update to learn about new features.

March2025 Carousel

Fabric Community Update - March 2025

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

Top Solution Authors (Last Month)
Top Kudoed Authors (Last Month)