Creating a Drop Down List via Data Validation
Drop-down lists are an extremely common feature in most of my popular Excel templates, including the meal planner, money manager, and many financial calculators. This Excel Tip will explain how you can create a drop-down list within a cell using data validation like the example shown in the image below (Fig 1). You can also use the Combo Box form field to create a drop down list, but this article is specifically about the data validation approach.
Hint: One of the reasons I prefer the data validation approach is that the list will work correctly when you open the file in OpenOffice. If use use a Combo Box, you have to redefine the linked cell after you open it with OpenOffice. Perhaps in the future, this will change, but for now ...
There are two main ways of creating your drop-down list. The first is to simply enter the list manually in the data validation dialog box as follows:
- Select the cell, or range of cells, where you want to add the drop-down list.
- Go to Data > Validation > Settings tab (see image below)
- Select "List" from the Allow: drop-down box
- Enter your list in the Source: field using a comma to separate the items
The problem with this approach is that if you use this in a lot of cells and later want to update the list, you have to do so in every single cell and there is a good chance you'll miss one. There is a much more elegant approach ...
Defining a Drop-Down List using a Range
Instead of manually entering the list of items in the data validation dialog box, you can reference a range of cells. For example, let's say I have a separate worksheet (Sheet2) with my list defined in cells A1:A3 as shown below. If I want to create a drop-down list within a cell on a different worksheet, I'll need to create a Named Range (Insert > Name > Define) that references this list. In this case, I've named the range "myList". You can later hide the worksheet containing your list to keep your workbook looking nice and clean.
In the data validation dialog box, instead of entering the list manually, you enter a reference to the named range in the Source: field as shown below:
If the validation range is on the same worksheet as your drop-down list, then you can use a reference like "=A1:A3". The named range approach is the only way I know of to get around the following error:
Note: When using a named range for a data validation list, the named range must be defined as a reference to a range of cells. If you're thinking of getting fancy and want to define a name without a cell reference, and succeed, please let me know how you did it.
Update (2/26/14): We've created a new Customer List Template that explains how to copy the customer list worksheet into a spreadsheet, create a drop-down list showing customer names, and then add lookup formulas to display the information for the chosen customer.
The article "Dynamic Drop-Down Lists" explains how to create drop-down lists that change based on user input, the date, check number, etc.
The article "Add Cool Features to Your To Do Lists in Excel" shows a few use for drop-down lists, including the examples below:
1. A simple drop-down list for selecting a priority value in a homework to do list:
2. Using a drop-down to create a checkbox field in a Task List