forked from KiaraGrouwstra/pquery
-
Notifications
You must be signed in to change notification settings - Fork 9
/
Table.ExpandAll.pq
45 lines (43 loc) · 1.82 KB
/
Table.ExpandAll.pq
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
/*
//Fully expands any nested records and tables within a table
//Originally written by Chris Webb: https://cwebbbi.wordpress.com/2014/05/21/expanding-all-columns-in-a-table-in-power-query/
//Usage:
Table.ExpandAll = Load("Table.ExpandAll"),
xml = Xml.Tables("<books><book><name>Book1</name><pages><page>1</page><page>2</page><page>3</page></pages></book><book><name>Book2</name><pages><page>1</page><page>2</page><page>3</page></pages></book></books>"),
Table.ExpandAll(xml) //, null, true
//Result: [an expanded version of the given table with nested records/tables]
*/
(
TableToExpand as table, //the table you wish to expand
optional ColumnNumber as number, //the column number to expand
optional AppendParentNames as logical //whether to use append parent column names e.g. "ul.li", or just keep "li" where possible (reverting to the qualified name in case of a colum name clash)
) as table =>
let
ColumnNumber = if (ColumnNumber=null) then 0 else ColumnNumber,
AppendParentNames = if (AppendParentNames=null) then false else AppendParentNames
in
List.Last(
List.Generate(
()=>[
col = ColumnNumber,
Tbl = TableToExpand
],
each [col]<=(Table.ColumnCount([Tbl])-1),
each let
ColumnNames = Table.ColumnNames([Tbl]),
ColumnName = ColumnNames{[col]},
ColumnsToExpand = List.Distinct(List.Combine(List.Transform(Table.Column([Tbl], ColumnName),
each if _ is table then Table.ColumnNames(_) else {}))),
NewColumnNames = List.Transform(ColumnsToExpand, each if (AppendParentNames or List.Contains(ColumnNames,_)) then ColumnName & "." & _ else _),
CanExpandCol = List.Count(ColumnsToExpand)>0
in [
Tbl = if CanExpandCol
then Table.ExpandTableColumn([Tbl], ColumnName, ColumnsToExpand, NewColumnNames)
else [Tbl],
col = if CanExpandCol
then [col]
else [col]+1
],
each [Tbl]
)
)