Power Query: Handling Dynamic Arrays
8 March 2023
Welcome to our Power Query blog. This week, I extract data from a Dynamic Array.
I have a list of trainee salespeople that I need to extract to Power Query, so that I can merge their details with another query:
data:image/s3,"s3://crabby-images/6bdd8/6bdd834bd555654644d9ac89d096925c020688c9" alt=""
Seems simple enough; I select the data and use ‘From Table/Range’ on the ‘Get & Transform’ section of the data tab:
data:image/s3,"s3://crabby-images/f90d8/f90d82d1c8fcf3fd4d11bb5926af006f21862ff3" alt=""
I don’t have any headers, so I take the defaults.
data:image/s3,"s3://crabby-images/05773/05773b93c2e20a641b3590b32340418629e35a3d" alt=""
The results are not good. If I click on the Error value, I see this:
data:image/s3,"s3://crabby-images/dc52e/dc52e75792c1ff25cf163b82dba3a99d9ab80627" alt=""
If I discard the query and go back to the sheet, I can see what has happened:
data:image/s3,"s3://crabby-images/eb5da/eb5da81e8f45633730ff53ac1d6cd1db85e3c42e" alt=""
To get a #SPILL! error, I must be dealing with a Dynamic Array. I use CTRL+ Z to undo the Table creation.
data:image/s3,"s3://crabby-images/5ea29/5ea29a92f4d96bcec355330b0884eedea9b8a2fc" alt=""
The list has been created using FILTER() which means that the output is a Dynamic Array. Obviously in this example, I can just use the original table, but let’s assume that I don’t have access to that.
I used ‘From Table/Range’ to extract the data, and so Power Query converted the data to a Table, which doesn’t currently work with Dynamic Arrays. I could however create a range.
In the ‘Name Manager’ on the Formulas tab, I can create a new range. If I just select the cells currently populated, this will be incorrect when I have more trainees. I need to create a dynamic range. This is the range I create:
data:image/s3,"s3://crabby-images/f9f0d/f9f0d7403879478bf3d900758f575035d9d05fc0" alt=""
The Excel formula is:
=Sheet1!$F$2#
This links to the data in the Dynamic Array created by the formula in cell $F$2. Now, I can create a blank query to access this range:
data:image/s3,"s3://crabby-images/7f258/7f258939cfd81c28a64492770ce2b4020acc48f9" alt=""
I create the Source step:
data:image/s3,"s3://crabby-images/da51e/da51e133a9cdecf3b608eb07a323e43f908ef645" alt=""
The M code is:
= Excel.CurrentWorkbook(){[Name="DR_Trainees"]}[Content]
This extracts the content from the range DR_Trainees in the current workbook.
Power Query generates a ‘Changed Type’ step, which I keep.
data:image/s3,"s3://crabby-images/b505c/b505c317775f4150d068b9af4e791bea40ed1936" alt=""
I don’t rename the columns yet, as I want to check that this query will refresh as expected. I use ‘Close & Load’ from the Home tab and create the output on a new sheet:
data:image/s3,"s3://crabby-images/8039b/8039bbd73812f51a09ea304ff205508c31ab1381" alt=""
Now I can add some new trainees to the original table:
data:image/s3,"s3://crabby-images/b27d6/b27d62988d7208e2b830beb8c914bfac025bc806" alt=""
The Dynamic Array updates immediately. I refresh theTrainee_list query:
data:image/s3,"s3://crabby-images/98eb1/98eb14cd9ed1a8d387dea4bacd8614a5c8ddd6ae" alt=""
The new trainees appear, and my list is complete. I can use Power Query to extract data from a Dynamic Array.
Come back next time for more ways to use Power Query!