Spill Range
Spill range is a term that refers to the range of values that a dynamic array formula produces and outputs onto the worksheet. The spill range is marked by a blue border and only the top-left cell contains the formula.
data:image/s3,"s3://crabby-images/a1b9d/a1b9d650a28571462a37b3d9e003108587d65050" alt=""
The spill range is dynamic and updates automatically as the source data changes. To refer to a whole spill range, you can use the spilled range operator (#
) after the address of the upper left cell in the range. For example, if you have a UNIQUE
formula in F2
cell that returns multiple values, you can reference all those values by typing =F2#
.
Creating a Unique Drop-Down List with Spill Range
Dynamic array formulas allow you to work with multiple values at the same time in a single formula. However, dynamic array formulas cannot be used directly in a Data Validation rule. So, in this example, we have used the UNIQUE
function in cell F2
to extract unique values from a cell range.
This formula returns a spill range of unique country names, which appear in F2:F12
. Using the #
symbol, we can then reference this spill range from the Data Validation dialog box. Follow these steps to create a Data Validation Drop-List From a Spill Range:
data:image/s3,"s3://crabby-images/60c19/60c19e8e2b5b266d5157d469cbac09c5da4f481a" alt=""
- Select the cell or range of cells you want to apply data validation to. I’ve selected
J2:J5
. - Go to
Data > Data Validation
. - Select
List
fromAllow
option in the Settings tab. - In the
Source
box enter$F$2#
. - Click
OK
.
data:image/s3,"s3://crabby-images/42918/42918ea5569a3db789169cffc75b0b5cff494b8c" alt=""
Creating Dependent Drop-Down List With Spill Range
We used UNIQUE
function to create our first drop-down list with spill range. To create a dependent list with a spill range based on the selection of the first drop-down we’ll use FILTER
function.
The FILTER
function allows you to extract data from a range based on the criteria that you specify. The function has three arguments:
- array – the range or array that you want to filter.
- include – defines the criteria for filtering
- if_empty – (optional) value that you can provide to display when there are no matching results.
We want to filter a range (A2:A17
) of cities data and only show the records (cities) where the country (B2:B17
) is selected in the drop-down cell on (J2
), you can use this formula:
=FILTER(A2:A17,B2:B17=J2,"Country is not selected.")
data:image/s3,"s3://crabby-images/e1464/e1464a6ab5906602290c194a1df93cbe98132a39" alt=""
In our scenario, City data is in column A and Country data is in column B. We want to create another drop-down list that shows cities of the selected country in the drop-down on J2
cell. To do this, first, we use the FILTER formula like =FILTER(A2:A17,B2:B17=J2,"")
in cell G2
. This will create a spill range in column G that shows only the cities of the country that is selected in the J2
cell data validation list.
data:image/s3,"s3://crabby-images/a3d07/a3d07fde056cf81b52df371521fe972a6c13b8d0" alt=""
Then, we apply the data validation in cell K2
and set the source to =G2#
. This way, whenever you change the country in J2, the dependent drop-down in cell K2
list will automatically update to reflect the changes.
Follow this link to watch how the dependent validation lists with spill range work.