Contextures

Hide Used Items in Drop Down List

Limit the choices in an Excel drop down list, by hiding items that have been previously selected. Several examples of how to use this technique, and workbooks to download.

Introduction

You can limit the choices in a drop down list, hiding items that have been previously selected. For example, if you are assigning employees to a shift, you don't want to assign the same employee twice.

In the drop down list shown below, Fred and Joe have been assigned, so their names aren't in the list now. The instructions for this workbook are shown below.

NOTE: If your version of Excel has Dynamic Arrays, use the much simpler instructions shown below. Dynamic arrays are available in Microsoft 365 plans.

names hidden if used

Thanks to Peo Sjoblom, who contributed the original formula for this technique, and to Daniel.M, who suggested the enhanced formulas.

Set up the Main Table

To set up the Employee Shift workbook, start by setting up the table in which you want to use the Excel Data Validation. In this example, the worksheet is named 'Schedule' and the range A1:C7 is being used.

Column B will have Data Validation applied.

Schedule worksheet

Create the List of Items

Create a list which contains the items you want to see in the Excel data validation dropdown list. Here, the employee names have been entered in cells A1:A6, on a sheet named 'Employees'

list of employee names

Calculate if a name has been used

Next, you'll add a formula beside each name, to check if that name has been used in the schedule.

1. On the Employees sheet, in cell B1, enter the following formula:

=IF(COUNTIF(Schedule!$B$2:$B$7,A1)>=1,"",ROW())

2. Copy the formula down to the last name, in cell B6.

This formula counts the occurrences of "Bert" in cells B2:B7 on the Schedule worksheet. If the count is greater than or equal to 1, the cell will appear blank. Otherwise, the row number will be displayed.

list of employee names

Create the list of unused names

The next step is to create a formula that will move any blank cells to the end of the list. There are two options:

1. For long lists, you can use the multi-cell array formula

2. For smaller ranges (fewer than 200 cells), use the single-cell formula, which is easier to edit.

Option 1: Multi-Cell Formula

  1. Select cells C1:C6
  2. Enter the following array formula (the formula is long, and should be all on one line)

    =IF(ROW(A1:A6)-ROW(A1)+1>COUNT(B1:B6),"",
        INDEX(A:A,SMALL(B1:B6,ROW(INDIRECT("1:"&ROWS(A1:A6))))))

3. Press Ctrl+Shift+Enter to enter the array formula in cells C1:C6

array formula moves blank cells to end

Option 2: Single-Cell Formula

If you'd prefer a single-cell formula (easier to edit), you could use this formula, also by Daniel.M. He recommends it for small ranges (<=200 cells):

  1. Select cell C1
  2. Enter the following formula (the formula is long, and should be all on one line)

    =IF(ROW(A1)-ROW(A$1)+1>COUNT(B$1:B$6),"",
    INDEX(A:A,SMALL(B$1:B$6,1+ROW(A1)-ROW(A$1))))

  3. Press Enter
  4. Copy the formula down to row 6

Name the List of Unused Names

Next, you'll create a named range, using the OFFSET function. Only the cells with names will be included, not the blank cells at the end of the list.

  1. On the Ribbon's Formulas tab, click Define Name
  2. In the Names in workbook box, type a one-word name for the range, e.g. NameCheck.
  3. In the Scope box, leave Workbook as the selection
  4. In the Refers to box, type the following formula (all on one line):
    • =OFFSET(Employees!$C$1,0,0,COUNT(Employees!$B$1:$B$6),1)
  5. Click OK

The OFFSET formula creates a range that starts in cell C1. The number of rows in the range is based on the count of numbers in cells B1:B6.

dynamic formula for range with names

Add the Drop Down Lists

Next, you'll use Excel's Data Validation feature, to create drop down lists on the Schedule sheet

  1. On the Schedule sheet, select cells B2:B7, where the employee names will be entered.
  2. On the Ribbon's Data tab, click Data Validation.
  3. From the Allow drop down list, choose List
  4. In the Source box, type an equal sign and the list name: =NameCheck
  5. Click OK.

add the drop down lists

Test the Drop Down List

Select an employee name in cell B2, and another name in cell B3.

When you open the list in cell B4, the list shows only the names that have NOT been used. Other names have been removed from the list.

names hidden if used

Employee List with Dynamic Arrays

If your version of Excel has Dynamic Arrays, use these instructions -- the setup is much simpler.

  • NOTE: Dynamic arrays are available in Excel for Office 365

On the Schedule sheet, there is a named table - tblSched. The table has 2 columns:

  • Day - Weekday names are typed in this column
  • Employee - use the drop down list of employee names to assign a person for each day

After an employee has been assigned, that name is removed from the drop down list.

In the screen shot below, Bert, Mike and Anne are no longer in the list.

select employee names for schedule

On the Lists sheet, there is a named table - tblEmp. The table has 1 column - EmpList.

Employee names are typed in that column. The list is sorted alphabetically, but does not need to be sorted.

select employee names for schedule

Available Employees List

Also on the Lists sheet, there is a dynamic array, starting in cell D2. The formula uses the new Excel functions, SORT and FILTER, combined with COUNTIF, to create a list of employees who have not been assigned on the Schedule sheet.

Here is the formula in cell D2:

  • =SORT(FILTER(tblEmp[EmpList], COUNTIF(tblSched[Employee], tblEmp[EmpList])=0))

The FILTER function returns:

  • Employee names from the EmpList column
  • For names that are not in the Employee column in the Schedule table (COUNTIF=0)

Then, the SORT function sorts the names alphabetically, for convenience when using the drop down list.

dynamic array with available names

Employee Drop Down List

On the Schedule sheet, data validation was used to create drop down lists in the Employee column. Those drop down lists are based on the dynamic array of available employee names.

In the data validation settings:

  • Allow was set for List
  • The Source is a formula that refers to the dynamic array starting cell, with the spill operator (#) at the end. That tells Excel to use the entire spill range for the dynamic array.
    • =Lists!$D$7#

data validation for drop down list

Other Examples

There are other examples of this Hide Used Items technique. You can download these sample files in the Download section.

Baseball Players

Select a player for each position, for each of the nine innings of a baseball game. After you choose a name in an inning, it disappears from that inning's drop down list. The lists for the other innings are not affected.

In the screen shot below, Mike was selected as the pitcher, so his name is not in the drop down list. Players who have been picked for the second inning still show up in the list for the first inning.

assign players per inning

Dependent Drop Downs

The "Hide Used Items" technique can also be adapted to work with dependent drop down lists.

In the screen shot below, a Type can be selected multiple times in column A. However, in column B, each dependent item can onlybe selected once.

For example, in cell B4, the SI-02 item is not in the SI list, because it was selected in cell B2.

dependent drop down list with hidden items

Selections Across a Row

In this example, the layout is different -- selections are made across a row, instead of down a column.

In the screen shot below, Cam's name is removed from the lists in Row 2, because he has already been assigned a task for that day.

selections made across a row

There are two versions of this sample file in the download section below:

  • All Versions - uses functions available in all version of Excel
  • Dynamic Arrays - uses functions available in Excel 2019 and Excel for Office 365

Hide Main Selection

In this example, people select their primary printer from a drop down list.

After that, they can select one or two backup printers, from the backup drop down lists. The primary printer does not appear in the backup lists.

selections made across a row

On the Lists sheet, there is a named range -- PrimaryList (green cells). There is a formula in the NotUsed column, to number all the printers, except the one selected as the Primary printer.

In column F, formulas create a list of Backup Printer, and the Primary printer isn't numbered in the NotUsed column, so it isn't included in the Backup List..

selections made across a row

Get the Workbooks

  1. Employee Schedule
  2. Baseball Players: Download the zipped workbook to Assign Baseball Players per Inning.
  3. Dependent Data Validation: Download the zipped workbook to Hide Used Items with Dependent Data Validation drop downs.
  4. Hide Used Selections Across a Row
    • All Excel Versions: Hide employee names if already used in the same row.This workbook uses Excel functions that are available in all versions - Single Task Sample File
    • Dynamic Array: Hide employee names if already used in the same row. This workbook uses new Excel functions and the Spill operator (#) - Single Task -Dynamic
  5. Remove Primary Printer from Backup List: Download the zipped workbook to hide the primary printer in the drop down lists for the Backup Printer selection cells.

Don't Miss Our Excel Tips

Don't miss my latest Excel tips and videos! Click OK, to get my weekly newsletter with Excel tips, and links to other Excel news and resources.

Get weekly Excel tips from Debra

 

More Tutorials

Data Validation Basics

Dependent Drop Down Lists

Data Validation Tips

 

Last updated: July 9, 2021 3:07 PM