Home » dplyr: How to Use a “not in” Filter

dplyr: How to Use a “not in” Filter

by Tutor Aspire

You can use the following basic syntax in dplyr to filter for rows in a data frame that are not in a list of values:

df %>%
  filter(!col_name %in% c('value1', 'value2', 'value3', ...))

The following examples show how to use this syntax in practice.

Example 1: Filter for Rows that Do Not Contain Value in One Column

Suppose we have the following data frame in R:

#create data frame
df frame(team=c('A', 'A', 'B', 'B', 'C', 'C', 'D', 'D'),
                 position=c('G', 'G', 'F', 'G', 'F', 'C', 'C', 'C'),
                 points=c(12, 14, 19, 24, 36, 41, 18, 29))

#view data frame
df

  team position points
1    A        G     12
2    A        G     14
3    B        F     19
4    B        G     24
5    C        F     36
6    C        C     41
7    D        C     18
8    D        C     29

The following syntax shows how to filter for rows where the team name is not equal to ‘A’ or ‘B’:

#filter for rows where team name is not 'A' or 'B'
df %>%
  filter(!team %in% c('A', 'B'))

  team position points
1    C        F     36
2    C        C     41
3    D        C     18
4    D        C     29

Example 2: Filter for Rows that Do Not Contain Value in Multiple Columns

Suppose we have the following data frame in R:

#create data frame
df frame(team=c('A', 'A', 'B', 'B', 'C', 'C', 'D', 'D'),
                 position=c('G', 'G', 'F', 'G', 'F', 'C', 'C', 'C'),
                 points=c(12, 14, 19, 24, 36, 41, 18, 29))

#view data frame
df

  team position points
1    A        G     12
2    A        G     14
3    B        F     19
4    B        G     24
5    C        F     36
6    C        C     41
7    D        C     18
8    D        C     29

The following syntax shows how to filter for rows where the team name is not equal to ‘A’ and where the position is not equal to ‘C’:

#filter for rows where team name is not 'A' and position is not 'C'
df %>%
  filter(!team %in% c('A') & !position %in% c('C'))

  team position points
1    B        F     19
2    B        G     24
3    C        F     36

Additional Resources

The following tutorials explain how to perform other common functions in dplyr:

How to Remove Rows Using dplyr
How to Select Columns by Index Using dplyr
How to Filter Rows that Contain a Certain String Using dplyr

You may also like