# R Select Rows by Condition with Examples

• Post author:

How do I select rows by the condition in R Data Frame? By using bracket notation you can select rows by single and multiple conditions from R Data Frame. In this article, I will explain how to select rows based on a list of values, by multiple and single conditions, not equal conditions e.t.c.

## 1. Quick Examples of Select Rows by Condition

The following are quick examples of how to select rows by condition from R DataFrame.

``````
# Quick Examples

# Select Rows by equal condition
df[df\$gender == 'M',]

# Select Rows by not equal condition
df[df\$gender != 'M',]

# Select Rows by Multiple Conditions
df[df\$gender == 'M' & df\$id > 15,]

# Select rows based on list
df[df\$id %in% c(13,14,15),]

# Using subset()
subset(df, gender == 'M')

# Using filter()
library("dplyr")
filter(df, gender == 'M')
``````

Let’s create an R DataFrame, run these examples and explore the output.

``````
# Create DataFrame
df <- data.frame(
id = c(10,11,12,13,14,15,16,17),
name = c('sai','ram','deepika','sahithi','kumar','scott','Don','Lin'),
gender = c('M','M','F','F','M','M','M','F'),
dob = as.Date(c('1990-10-02','1981-3-24','1987-6-14','1985-8-16',
'1990-10-02','1981-3-24','1987-6-14','1985-8-16')),
state = c('CA','NY',NA,NA,'DC','DW','AZ','PH')
)
df
``````

Yields below output.

``````
# Output
id    name gender        dob state
1 10     sai      M 1990-10-02    CA
2 11     ram      M 1981-03-24    NY
3 12 deepika      F 1987-06-14  <NA>
4 13 sahithi      F 1985-08-16  <NA>
5 14   kumar      M 1995-03-02    DC
6 15   scott      M 1991-06-21    DW
7 16     Don      M 1986-03-24    AZ
8 17     Lin      F 1990-08-26    PH
``````

## 2. Select Rows Based on Condition

By using bracket notation we can select rows by the condition in R. In the following example I am selecting all rows where `gender` is equal to ‘M’ from DataFrame. For more examples refer to selecting rows from the data frame.

``````
# Select Rows by equal condition
df[df\$gender == 'M',]

# Output
#  id  name gender        dob state
#1 10   sai      M 1990-10-02    CA
#2 11   ram      M 1981-03-24    NY
#5 14 kumar      M 1995-03-02    DC
#6 15 scott      M 1991-06-21    DW
#7 16   Don      M 1986-03-24    AZ
``````

## 3. Select Rows Based on Negative Condition

Similarly, the below example performs negation. here I am selecting all rows that are not equal to ‘M’.

``````
# Select Rows by not equal condition
df[df\$gender != 'M',]

# Output
#  id    name gender        dob state
#3 12 deepika      F 1987-06-14  <NA>
#4 13 sahithi      F 1985-08-16  <NA>
#8 17     Lin      F 1990-08-26    PH
``````

## 4. Select Rows Based on Multiple Conditions

Let’s see how to select rows based on multiple conditions in R. In the below example I am selecting rows when gender is equal to M and id is greater than 15. Here I am using `&` (AND) logical operator, It returns true when both conditions are true.

Similarly, you can also use | (or), and ! (not) conditions. You can also use && and || operators.

``````
# Select Rows by Multiple Conditions
df[df\$gender == 'M' & df\$id > 15,]

# Output
#  id name gender        dob state
#7 16  Don      M 1986-03-24    AZ
``````

## 5. Select Rows Based on a List of Values

If you have a vector of values and you wanted to select rows based on a list of values (vector values) in R, use in operator `%in%` . The below example returns rows that have id values 13,14 and 15.

``````
# Select rows based on list
df[df\$id %in% c(13,14,15),]

# Output
#  id    name gender        dob state
#4 13 sahithi      F 1985-08-16  <NA>
#5 14   kumar      M 1995-03-02    DC
#6 15   scott      M 1991-06-21    DW
``````

## 6. By Using subset()

R base also provides a subset() function that can be used to select rows based on the logical condition of a column.

``````
# Using subset()
subset(df, gender == 'M')
``````

## 7. By using filter()

Finally, you can achieve selecting rows from the data frame by using the filter() function from the dplyr package. In order to use this package, first, you need to install it by using `install.packages("dplyr")` and load it using `library("dplyr")`.

``````
library("dplyr")

# Using filter()
filter(df, gender == 'M')
``````

## 8. Conclusion

In this article, you have learned R examples of how to select rows from DataFrame by single condition, multiple conditions, by not-equal condition, and finally, select rows based on a list of values.

## References

### NNK

SparkByExamples.com is a Big Data and Spark examples community page, all examples are simple and easy to understand and well tested in our development environment Read more ..