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

Get Fabric Certified for FREE during Fabric Data Days. Don't miss your chance! Request now

Reply
tatmaninov
Frequent Visitor

How to list all direct and indirect linked values

I am working in Excel Power Query and I am trying to take a table that details relationships between two values example below

FromTo
AB
BC
CD
CE
XY
YZ

 

And output this

FromTo
A{B,C,D,E}
X{Y,Z}

 

Would really appreciate a steer or pointers about how I can do this.

 

1 ACCEPTED SOLUTION
ZhangKun
Super User
Super User

let
    dataTable = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WclTSUXJSitWJBpI6Ss5gljOQ5QJnuYJZEUBWJJgVCWRFKcXGAgA=", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [From = _t, To = _t]),
    fx = (tbl, s) => 
        let 
            a = List.Combine(List.Transform(s, (v) => Table.SelectRows(tbl, each [From] = v)[To]))
        in 
            if List.Count(a) = 0 then {} else (a & @Fx(tbl, a)), 
    result = Table.AddColumn(
        Table.SelectRows(dataTable, each Table.RowCount(Table.SelectRows(dataTable, (r) => r[To] = [From])) = 0)[[From]], 
        "To", 
        each "{" & Text.Combine(fx(dataTable, {[From]}), ",") & "}"
    )
in
    result

View solution in original post

2 REPLIES 2
tatmaninov
Frequent Visitor

Amazing!, thank you!

ZhangKun
Super User
Super User

let
    dataTable = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WclTSUXJSitWJBpI6Ss5gljOQ5QJnuYJZEUBWJJgVCWRFKcXGAgA=", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [From = _t, To = _t]),
    fx = (tbl, s) => 
        let 
            a = List.Combine(List.Transform(s, (v) => Table.SelectRows(tbl, each [From] = v)[To]))
        in 
            if List.Count(a) = 0 then {} else (a & @Fx(tbl, a)), 
    result = Table.AddColumn(
        Table.SelectRows(dataTable, each Table.RowCount(Table.SelectRows(dataTable, (r) => r[To] = [From])) = 0)[[From]], 
        "To", 
        each "{" & Text.Combine(fx(dataTable, {[From]}), ",") & "}"
    )
in
    result

Helpful resources

Announcements
Fabric Data Days Carousel

Fabric Data Days

Advance your Data & AI career with 50 days of live learning, contests, hands-on challenges, study groups & certifications and more!

October Power BI Update Carousel

Power BI Monthly Update - October 2025

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

FabCon Atlanta 2026 carousel

FabCon Atlanta 2026

Join us at FabCon Atlanta, March 16-20, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM.