Power Query: Table of Tables
8 April 2020
Welcome to our Power Query blog. This week, I look at how to reformat a table of data which is made up of sub-tables.
I have the following data from my imaginary salespeople:
data:image/s3,"s3://crabby-images/2a041/2a0415903d7c81c2b634cdf625d171821bc815b1" alt=""
I have information for three of my salespeople, but I’d like to reformat my data so that I have everything in separate columns. I begin by extracting my data to Power Query using the ‘From Table’ option in the ‘Get & Transform’ section on the Data tab.
data:image/s3,"s3://crabby-images/4f75b/4f75b20b2e640a5759649c460cd17b68624469ed" alt=""
I accept the default area, but I uncheck the ‘My table has headers’ section since the headings at the top are not for all the data.
data:image/s3,"s3://crabby-images/ccb0f/ccb0fd061afe0a31eed8215cc4cc4ad72cec61bc" alt=""
I remove the ‘Changed Type’ step since it is serving no purpose here.
data:image/s3,"s3://crabby-images/5411f/5411f6c618069b6e20748b30d38e446ce08fac88" alt=""
My data is clearly made up of three separate tables, so I will split this table using the M function Table.Split():
Table.Split(table as table, pageSize as number) as list
This function splits the table into a list of tables, where the first element of the list is a table containing the first pageSize rows from the source table, the next element of the list is a table containing the next pageSize rows from the source table, etc.
Since each of my sub-tables is the same size, this will work for my example. I add a step using the fx button.
data:image/s3,"s3://crabby-images/16829/16829895cd1d852f9c96dc7fb0aaba4b649c4feb" alt=""
The M code I have used is:
=Table.Split(Source, 4)
This will split the table extracted as ‘Source’ into tables of four (4) rows.
data:image/s3,"s3://crabby-images/6d647/6d647fc6123e156c4ebe9f18470bbd268808b630" alt=""
When I execute this step, I see that I get a list of three tables, and when I click the space next to ‘Table’ I can see the data in each table. I need to know what to do to each of my tables, and then put it into a function to use against my list.
I start with one of the tables, and transform my data:
data:image/s3,"s3://crabby-images/479f7/479f7a798e6309a557f67389a7107699e7af8c02" alt=""
This gives me my function body. I now need to convert this to a function.
data:image/s3,"s3://crabby-images/ba266/ba2661a4ec18bbc0fc731ac5ebd3b6bc1563f4c2" alt=""
Once I click ‘Done’, my function prompts for a table:
data:image/s3,"s3://crabby-images/a51ab/a51ab71276ee35f201e971cdcbfc937f260ab381" alt=""
Now I can go back to my list of tables, and apply my function.
data:image/s3,"s3://crabby-images/30f6a/30f6a952446c795387bfec1e3fcdbb15480d97a1" alt=""
I need to apply my function to my list using List.Transform(). The M code I use is
= List.Transform(Custom1, myfunction)
data:image/s3,"s3://crabby-images/8a7a3/8a7a3e4fb9e47975e5b2ee220f545ede75bd9302" alt=""
I can see that the data within the tables in my list has been transformed.
My final step is to glue my tables back together. I use Table.Combine() for this. My M code is:
= Table.Combine(Custom2)
data:image/s3,"s3://crabby-images/27fd5/27fd5040238d80c346e8808b2f3cb0b9726a7bda" alt=""
My data is transformed into one large table.
Come back next time for more ways to use Power Query!