data:image/s3,"s3://crabby-images/43bac/43bac1378b0fd4cf509bb70d870f80a9a32e9585" alt="How to Create Index Columns Using Dynamically Spilled Arrays"
Add an index column to any dynamic array using a few of the latest Excel functions for easy lookups.
Contents:
How to Add an Index Column to a Dynamic or Spilled Array
Formula
This formula will add a numbered sequence, starting from 1, to the front of any array.
= HSTACK(SEQUENCE(ROWS(array)),array)
Explanation
Let's say that we're working on a lookup table for a list of customers.
We're starting off with a dynamic array in cell C4# that is linked to the table "Customer_Table", and automatically updates as the customer table does.
data:image/s3,"s3://crabby-images/159c9/159c921632dcc766f85305796eea34ee35075404" alt="Spilled dynamic array"
It can be useful to add an index column (a numbered column that increases by 1 for each entry), but to do this automatically we need a few different functions. HSTACK, SEQUENCE, and ROWS.
= HSTACK(SEQUENCE(ROWS(array)),array)
SEQUENCE Function
The first thing we need to understand is the sequence function. This function will create an incrementing list from any starting number. For example, the formula:
= SEQUENCE(5)
data:image/s3,"s3://crabby-images/d4da4/d4da46e11a8c108683ff0dc99aaa2fc83d2aee4c" alt="excel sequence function to spill array"
Creates a dynamic array that begins with the number 1, and increases by 1 each row, spilling downward.
This creates the basis for our index column. The next thing we need to know is how many rows are in our original array.
Counting the Number of Rows in Array
To count the number of rows in our array, and also know the number that the sequence function should increase too, we can use the ROWS function.
The ROWS function counts how many rows currently exist in a dynamic or spilled array.
data:image/s3,"s3://crabby-images/c1eb3/c1eb3d50ef724dce6698e41b88c151390cda0d3f" alt="excel ROWS function to count rows in spilled dynamic array"
In this case, since our array is held in C4#, and is 6 rows long, the formula returns a 6.
This number is then fed into the SEQUENCE function, which creates a numbered list from 1 through 6.
data:image/s3,"s3://crabby-images/12792/12792c66e31a1981d3ba341d6939df19a43e8b34" alt="Excel combining the ROWS function and SEQUENCE function"
Now we just need to combine our index column with the rest of the dynamic array.
Combining Two Dynamic Arrays
To do that we'll use the HSTACK function. With HSTACK we can horizontally combine two different arrays together.
In this case, the two arrays that we want to combine are the index column, using the formula:
= SEQUENCE(ROWS(C4#))
As well as the rest of the array held in C4#.
Here are the two pieces we have to horizontally combine:
data:image/s3,"s3://crabby-images/37b57/37b57929a605452396a027a84f10281c081c4eb6" alt="Combining Two Dynamic Arrays using HSTACK"
To combine them, we just need to drop both arrays into HSTACK together with our final formula:
= HSTACK(SEQUENCE(ROWS(C4#)),C4#)
data:image/s3,"s3://crabby-images/a4747/a474716071082b9bb423ba88dad78ab79af8581e" alt="Combining two spilled arrays using HSTACK to create an index lookup column"