Excel: Create Cascading Drop-Down Lists for Better Data Validation and Quality Control
When using Microsoft Excel to track data, one challenge is maintaining data quality when multiple people collaborate on the same workbook. Excel’s data validation feature helps by limiting data input to pre-defined options in a list. This works well for individual cells, but if one column depends on the value of another, you’ll need a more advanced solution. This guide explains how to create cascading drop-down lists in Excel using data validation and named ranges.
Instructions
Step 1: Define the Reference Data
We’ll assume you are collecting data with organization and department attributes. In this example, an organization is the parent of one or more departments. Set up your reference data on a separate worksheet, such as REFERENCES
, as follows:
- Column A (
REF_ORGANIZATIONS
) lists valid organizations for the organization drop-down list. In the sample data, we have three organizations namedOrganization 1
,Organization 2
, andOrganization 3
. - Column B (
REF_ORGANIZATION_TO_DEPARTMENT_MAPPINGS
) lists the names of three ranges that map departments to an organization. - Column D (
REF_ORGANIZATION_1_DEPARTMENTS
) lists valid departments forOrganization 1
. - Column E (
REF_ORGANIZATION_2_DEPARTMENTS
) lists valid departments forOrganization 2
. - Column F (
REF_ORGANIZATION_3_DEPARTMENTS
) lists valid departments forOrganization 3
.
data:image/s3,"s3://crabby-images/54d4a/54d4afaff5c45093cc10cd7f5800a8b4582fb2ac" alt="Reference Data"
Step 2: Define the Named Ranges
Now, define the named ranges referring to these reference lists.
- From the
Formulas
ribbon, clickName Manager
. - Click the
New...
button. - The
New Name
dialog box is displayed. - In the
Name
field, enter theREF_
name specified in Step 1. - In the
Refers to
field, enter or select the cell range containing the associated reference data. - Click the
OK
button. - Repeat steps for each named range.
NOTE: The key range,
REF_ORGANIZATION_TO_DEPARTMENT_MAPPINGS
, links departments to an organization. This named range must include the values in both Column A and Column B in itsRefers to
field. Also, ensure the values in Column B match the department named ranges. This link will be used in aVLOOKUP
andINDIRECT
formula in a subsequent step.
data:image/s3,"s3://crabby-images/d3078/d3078caf605f4c1f200446c23714d5cb11e83f3c" alt="Named Ranges"
Step 3: Define the Organization Data Validation (Parent Column)
On the data collection worksheet, such as DATA
, set up data validation for the organization column (Column A). This will display a drop-down list of valid organizations.
- Highlight the organization column (Column A).
- From the
Data
ribbon, clickData Validation
. - The
Data Validation
dialog box is displayed. - In the
Allow
dropdown, selectList
. - In the
Source
field, enter=REF_ORGANIZATIONS
. - Enable the
Ignore blank
checkbox. - Enable the
In-cell dropdown
checkbox. - Click the
OK
button.
data:image/s3,"s3://crabby-images/a37ed/a37edae8b0dfaaa8e396ce05585f2baf5eef930a" alt="Data Validation: Organization"
Step 4: Define the Department Data Validation (Child Column)
On the data collection worksheet, in this example DATA
, create the data validation rule for the department column (Column B) using the following formula. This formula uses VLOOKUP
to find the correct department range based on the selected organization and uses INDIRECT
to reference that range.
- Highlight the department column (Column B).
- From the
Data
ribbon, clickData Validation
. - The
Data Validation
dialog box is displayed. - In the
Allow
dropdown, selectList
. - In the
Source
field, enter the formula. - Enable the
Ignore blank
checkbox. - Enable the
In-cell dropdown
checkbox. - Click the
OK
button. - You might see the error message
The Source currently evaluates to an error. Do you want to continue?
— click theYes
button to proceed.
=INDIRECT(VLOOKUP(A2,REF_ORGANIZATION_TO_DEPARTMENT_MAPPINGS,2,FALSE))
data:image/s3,"s3://crabby-images/bc22d/bc22d0b05a07f41f54e58dae4e1bd3666d02287f" alt="Data Validation: Department"
data:image/s3,"s3://crabby-images/3aa44/3aa4474a10c8f92a2efa71948ac7f2234c428546" alt="Data Validation: Source Evaluation Error Message"
Step 5: Test the Cascading Drop-down Lists
After setting up data validation, test the cascading drop-down lists. Selecting an organization will filter the department list to only show relevant options for that organization.
data:image/s3,"s3://crabby-images/d4cda/d4cda456a8d5687e1077335bb27876aae05d8504" alt="Cascading Drop-down List Test"
Step 6: Macro to Validate Parent/Dependent Relationship
To prevent errors, such as selecting a department that no longer matches the chosen organization, you can add a macro to update the department column when the organization selection changes.
Save the file as a macro-enabled workbook and add the following code to the worksheet. The macro will clear the department entry if it is no longer valid. Adjust the code based on your specific columns.
- From the
Developer
ribbon, clickVisual Basic
. - The
Microsoft Visual Basic for Applications
window is displayed. - Select the data collection worksheet, in this case
DATA
. - Add the following code.
- Close the window and return to Excel.
Option Explicit
Private Sub Worksheet_Change(ByVal Target As Range)
On Error GoTo exitHandler
With Application
.EnableEvents = False
.ScreenUpdating = False
End With
If Target.Column = 1 Then
If Target.Validation.Type = xlValidateList Then
If Not Target.Offset(0, 1).Validation.Value Then
Target.Offset(0, 1).ClearContents
End If
End If
End If
exitHandler:
With Application
.EnableEvents = True
.ScreenUpdating = True
End With
End Sub
data:image/s3,"s3://crabby-images/c3e42/c3e42912049a00ee08bc32ac6287670de52df0e3" alt="VBA Macro to Validate Data Quality"
Results
After selecting an organization from the drop-down list, the department list shows only departments linked to that organization. Choosing a different organization triggers the macro, clearing the invalid department selection.
data:image/s3,"s3://crabby-images/797a2/797a29736b6350bc8c1844aa08a9e697e33553f6" alt="Excel: Cascading Drop-down List"
Summary
By setting up cascading drop-down lists in Excel, you can maintain accurate and consistent data entry in multi-user workbooks. This process uses data validation, named ranges, and formulas like VLOOKUP
and INDIRECT
to create dynamic, dependent selections. With the addition of a macro, you can further ensure data integrity by automatically correcting any mismatches between parent and child values.