From 46d9a7395c013bb6cef8abf459d6167166bf9b06 Mon Sep 17 00:00:00 2001 From: carriewright11 Date: Fri, 6 Dec 2024 12:34:01 -0500 Subject: [PATCH] adding extra slides about nuance of filter order --- .../Subsetting_Data_in_R.Rmd | 24 +++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/modules/Subsetting_Data_in_R/Subsetting_Data_in_R.Rmd b/modules/Subsetting_Data_in_R/Subsetting_Data_in_R.Rmd index 8c020013..2ee07f87 100644 --- a/modules/Subsetting_Data_in_R/Subsetting_Data_in_R.Rmd +++ b/modules/Subsetting_Data_in_R/Subsetting_Data_in_R.Rmd @@ -1002,6 +1002,30 @@ select(er_30, starts_with(c("r", "l"))) # here we combine two patterns ``` +## Nuances about `filter()` + +```{r} +test <- tibble(A = c(1,2,3,4), B = c(1,2,3,4)) +test + +# These are technically the same but >= is easier to read +# Separating can cause issues +filter(test, B > 2 | B==2) +filter(test, B >= 2) +``` + +## Order of operations for `filter()` + +Order can matter. Think of individual statements separately first. +```{r} + +filter(test, A>3 | B==2 & B>2) # A is greater than 3 or B is equal to 2 AND (think but also) B must be greater than 2 , thus 2 is dropped. +filter(test, A>3 & B>2 | B==2) # A is greater than 3 AND B is greater than 2 leaving only 4s OR B is equal to 2, (since this comes later, 2 is preserved) +``` + + + + ## Ordering the column names of a data frame: alphabetically {.codesmall} Using the base R `order()` function.