Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Be one of the first to start using Fabric Databases. View on-demand sessions with database experts and the Microsoft product team to learn just how easy it is to get started. Watch now

Reply
LearnerBI
Frequent Visitor

Re-arranging Column Data (Unpivoted, but I have multiple records, how to get grouped to ID)

Hi Experts,

I have extracted jira, unfortunately has 10 components and there was no consistency in entering data, so when I extracted to .CSV, I have data spred across in 10 columns. 

What I tried:

1. I have Unpivoted the data and created a conditional columns to make it uniform 

2. I have right columns but now multiple rows of same data depending on how many components are entered

Now I have to re-order all data to a single row, so when I tried Group By,  I get back my rows but with column Records when I expand to get newly created columns, I still get multiple rows of data .

 

This is the m code, i have after re-arranging columns but now I need to pivot and group to the record. 

let
Source = Excel.CurrentWorkbook(){[Name="Table1"]}[Content],
#"Changed Type" = Table.TransformColumnTypes(Source,{{"Issue Type", type text}, {"Issue key", type text}, {"Issue id", Int64.Type}, {"Status", type text}, {"Summary", type text}, {"Custom field (Epic Link)", type text}, {"Custom field (Product Summary Title)", type any}, {"Assignee", type text}, {"Created", type text}, {"Creator", type text}, {"Custom field (Child Requirement)", type text}, {"Component/s", type text}, {"Component/s2", type text}, {"Component/s3", type text}, {"Component/s4", type text}, {"Component/s5", type text}, {"Component/s6", type any}, {"Component/s7", type any}, {"Component/s8", type any}, {"Component/s9", type any}, {"Resolution", type text}, {"Custom field (Epic Status)", type any}, {"Custom field (Run Status)", type any}}),
#"Unpivoted Only Selected Columns" = Table.Unpivot(#"Changed Type", {"Component/s", "Component/s2", "Component/s3", "Component/s4", "Component/s5", "Component/s6", "Component/s7", "Component/s8", "Component/s9"}, "Attribute", "Value"),
#"Added Conditional Column" = Table.AddColumn(#"Unpivoted Only Selected Columns", "Comp1", each if Text.Contains([Value], "Sage Appli") then [Value] else null),
#"Added Conditional Column1" = Table.AddColumn(#"Added Conditional Column", "Comp2", each if Text.Contains([Value], "Phase") then [Value] else null),
#"Added Conditional Column2" = Table.AddColumn(#"Added Conditional Column1", "Comp3", each if Text.Contains([Value], "UAT") then [Value] else if Text.Contains([Value], "Acceptance") then [Value] else null),
#"Added Conditional Column3" = Table.AddColumn(#"Added Conditional Column2", "Comp4", each if [Value] = [Comp1] then "" else if [Value] = [Comp2] then "" else if [Value] = [Comp3] then "" else [Value])

in
#"Added Conditional Column3"

 

How to Unpivot with unique records.png

Please can you help me fix it ? Please note as this is extract from Jira, I have loads of columns. 

 

I do not want to use xlookup to fix this as, it is pain with records and times I have to do. Any help would be appreciated.

- No I have no idea much in writing M code, but I can follow instructions, ( Note, Loads of all Jira columns ) 

Please help

 

 

 

 

 

1 ACCEPTED SOLUTION

What are you trying to do?  Leave the other columns alone?  Just leave them alone.  Do not touch them.  Do not add them into the merge.  The only columns that will be impacted are the columns you decide to merge.

 

spinfuzer_0-1707380841053.png

 

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("XY/NDoIwEITfZc9cxB+ewhuJB9KD0tWiyB4o78+sY0hDMplmm/lm266TQ32USlqdM46rTfD7o4dHfcJfaYC/PyP8OxkcGjVLqJw9YcppmL1i0Y0qG0ixwUf9o2cMvUWHbhp3KKFyuS/yRxK+8IYqX0rxU7925hsPmPmaNi279CYkJIQV", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [#"test1 " = _t, test2 = _t, #"test 3" = _t, Component1 = _t, Component2 = _t, Component3 = _t, #"Component4 " = _t, component5 = _t, Component6 = _t, #"test 4" = _t]),
    /// group your columns/values into the record below
    order = [ abc = "Component1", def = "Component2", ghi = "Component3", jkl = "Component4",
        mno = "Component5", 123 = "Component4"],
    #"Changed Type" = Table.TransformColumnTypes(Source,{{"Component1", type text}, {"Component2", type text}, {"Component3", type text}, {"Component4 ", type text}, {"component5", type text}, {"Component6", Int64.Type}}),
    #"Replaced Value" = Table.ReplaceValue(#"Changed Type","",null,Replacer.ReplaceValue,{"test1 ", "test2", "test 3", "Component1", "Component2", "Component3", "Component4 ", "component5", "Component6", "test 4"}),
    /// merge columns
    #"Merged Columns" = Table.CombineColumns(Table.TransformColumnTypes(#"Replaced Value", {{"Component6", type text}}, "en-US"),{"Component1", "Component2", "Component3", "Component4 ", "component5", "Component6"},each List.RemoveMatchingItems(List.Combine({_}), {"", null}),"Merged"),
    transform = Table.TransformColumns(#"Merged Columns", {"Merged", each Record.Combine(List.Transform(_, (x) => Record.AddField([], Record.Field(order,x), x)))} ),
    #"Expanded Merged" = Table.ExpandRecordColumn(transform, "Merged", {"Component1", "Component2", "Component3", "Component4", "Component5"}, {"Component1", "Component2", "Component3", "Component4", "Component5"}) 

in
    #"Expanded Merged"

 

 

 

 

View solution in original post

8 REPLIES 8
spinfuzer
Super User
Super User

See example.

 

Let me know if the speed is not good.  If so I can try to make it faster.  If two components have the same grouping in one row, one will override the other. (e.g. if you have abc and def are both component 1, it will only show one of the two values in component1).

 

1) Create a record with the component value as the field name and desired column name as the value

2) Combine all the columns into a List and remove nulls and blank values

3) Tranform the list into a list of records and combine the records

4) Expand the record column

 

 

 

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WSkxKVtJRSklNA5LpGZlAMis7B0jm5uUDSQWlWJ1oqCyySogsRCWmGogssmkQNWgWQZChkTFYElkMguCa4AhuWCwA", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [Component1 = _t, Component2 = _t, Component3 = _t, #"Component4 " = _t, component5 = _t, Component6 = _t]),
    /// group your columns/values into the record below
    order = [ abc = "Component1", def = "Component2", ghi = "Component3", jkl = "Component4",
        mno = "Component5", 123 = "Component4"],
    #"Changed Type" = Table.TransformColumnTypes(Source,{{"Component1", type text}, {"Component2", type text}, {"Component3", type text}, {"Component4 ", type text}, {"component5", type text}, {"Component6", Int64.Type}}),
    /// merge columns
    #"Merged Columns" = Table.CombineColumns(Table.TransformColumnTypes(#"Changed Type", {{"Component6", type text}}, "en-US"),{"Component1", "Component2", "Component3", "Component4 ", "component5", "Component6"},each List.RemoveMatchingItems(List.Combine({_}), {"", null}),"Merged"),
    transform = Table.TransformColumns(#"Merged Columns", {"Merged", each Record.Combine(List.Transform(_, (x) => Record.AddField([], Record.Field(order,x), x)))} ),
    #"Expanded Merged" = Table.ExpandRecordColumn(transform, "Merged", {"Component1", "Component2", "Component3", "Component4", "Component5"}, {"Component1", "Component2", "Component3", "Component4", "Component5"}) 

in
    #"Expanded Merged"

 

 

@spinfuzer 

 

Thank you very much @spinfuzer  Yes it worked like charm in my test data, before I try on actual data, I need to create a group as you created.

order = [ abc = "Component1", def = "Component2", ghi = "Component3", jkl = "Component4",
        mno = "Component5", 123 = "Component4"],

Please may I know if this works as i have 10 -12 combinations of strings to me categorised into one component

order = [ abc OR 2323 OR sdfsfe OR Finance OR Cash OR Approve = "Component1", def = "Component2", ghi = "Component3", jkl = "Component4",
        mno = "Component5", 123 = "Component4"],

 

1. Is this right ? abc OR 2323 OR sdfsfe OR Finance OR Cash OR Approve = "Component1" to assign the combinations into components ?

2. I believe with above script, I do not have to Pivot the data right ?

Hi @spinfuzer  I have got a new 5 sets of data and came to test and accept as solution but I am bit confused with 10 columns before the Components 1, 2,3 ....9. and 10 colums to the right and I would like them to retain the same. I tried to add those columns in the merge. Please can you help me

test1 test2test 3Component1Component2Component3Component4 component5Component6test 4

123

TestMonabcdefghijklmno let
124thisTuedefabcdefmnojkl me
125codeWeddefabcmnoghijkl test
126   defghi  123code
127goodThughi     goo
       jkl  

 

 

The output is exactly same except the other columns are not changed at all 

Expected output

test1test2test3Component1Component2Component3Component4 component5test4

123

TestMonabcdefghijklmnolet
124thisTueabcdefghijklmnome
125codeWedabcdefghijklmnotest
126   defghi123 code
127goodThu  ghi  goo

 

based on how you manage to handle the columns not managed, I will take that logic into my data to do & this time with your code. Thanks a lot 

What are you trying to do?  Leave the other columns alone?  Just leave them alone.  Do not touch them.  Do not add them into the merge.  The only columns that will be impacted are the columns you decide to merge.

 

spinfuzer_0-1707380841053.png

 

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("XY/NDoIwEITfZc9cxB+ewhuJB9KD0tWiyB4o78+sY0hDMplmm/lm266TQ32USlqdM46rTfD7o4dHfcJfaYC/PyP8OxkcGjVLqJw9YcppmL1i0Y0qG0ixwUf9o2cMvUWHbhp3KKFyuS/yRxK+8IYqX0rxU7925hsPmPmaNi279CYkJIQV", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [#"test1 " = _t, test2 = _t, #"test 3" = _t, Component1 = _t, Component2 = _t, Component3 = _t, #"Component4 " = _t, component5 = _t, Component6 = _t, #"test 4" = _t]),
    /// group your columns/values into the record below
    order = [ abc = "Component1", def = "Component2", ghi = "Component3", jkl = "Component4",
        mno = "Component5", 123 = "Component4"],
    #"Changed Type" = Table.TransformColumnTypes(Source,{{"Component1", type text}, {"Component2", type text}, {"Component3", type text}, {"Component4 ", type text}, {"component5", type text}, {"Component6", Int64.Type}}),
    #"Replaced Value" = Table.ReplaceValue(#"Changed Type","",null,Replacer.ReplaceValue,{"test1 ", "test2", "test 3", "Component1", "Component2", "Component3", "Component4 ", "component5", "Component6", "test 4"}),
    /// merge columns
    #"Merged Columns" = Table.CombineColumns(Table.TransformColumnTypes(#"Replaced Value", {{"Component6", type text}}, "en-US"),{"Component1", "Component2", "Component3", "Component4 ", "component5", "Component6"},each List.RemoveMatchingItems(List.Combine({_}), {"", null}),"Merged"),
    transform = Table.TransformColumns(#"Merged Columns", {"Merged", each Record.Combine(List.Transform(_, (x) => Record.AddField([], Record.Field(order,x), x)))} ),
    #"Expanded Merged" = Table.ExpandRecordColumn(transform, "Merged", {"Component1", "Component2", "Component3", "Component4", "Component5"}, {"Component1", "Component2", "Component3", "Component4", "Component5"}) 

in
    #"Expanded Merged"

 

 

 

 

Thank you @spinfuzer

Much appreciated.

You are creating a record.  The field name must be a text value, just like Table Column Names.

 

The record syntax is

[ FieldName1 = FieldValue1, FieldName2 = FieldValue2, ... ]

 

or

 

[ aaaa = "Component1", bbbb = "Component1", .... ]

assuming aaaa and bbbb are grouped as component1.

 

Be careful with your grouping, if your row has both aaaa and bbbb in the same row, it willl only take one of the two values and put a single value into component1.

 

There are no pivot/unpivot steps here.

v-junyant-msft
Community Support
Community Support

Hi @LearnerBI ,

Sorry but I can't understand what do you mean by "Now I have to re-order all data to a single row"? Can you show your expected results in the form of a screenshot?

Best Regards,
Dino Tao

Hello @v-junyant-msft  

Thank you for getting back 

I should have updated this, I apologise. What I did was to create Huge 4 levels of conditional columns and trying to do the same without Unpivoting. It would be nice, I can get this in a smart way. 

------------------------------------------------------------

Users in jira did not enter components in the same order 

-----------------------

AS- IS -- Example: (We have 9 components that come from jira) - -Not in right order, so I not able to do create report

 

Component1Component2Component3Component4 component5Component6
abcdefghijklmno 
defabcdefmnojkl 
defabcmnoghijkl 
 defghi  123
ghi     
    jkl 

-- etc

 

- -What I aim to get for all the 9 components is re-order the following way (Note: I don't need all 9 components, so i must have the abiity to group them, so they are into one column, like Add custom column If col 1 = "abc" else if col 2 ="abc" else if ... col 9 ="abc" than  component 1 = "abc" else "Null" )

Component1Component2Component3Component4 component5
abcdefghijklmno
abcdefghijklmno
abcdefghijklmno
 defghi123 
  ghi  

-etc

Anything you can help kindly.

 

Regards & Thanks

Helpful resources

Announcements
ArunFabCon

Microsoft Fabric Community Conference 2025

Arun Ulag shares exciting details about the Microsoft Fabric Conference 2025, which will be held in Las Vegas, NV.

December 2024

A Year in Review - December 2024

Find out what content was popular in the Fabric community during 2024.

Top Solution Authors
Top Kudoed Authors