seplyr
is an attempt to work with the dplyr
0.7.*
R
package through standard evaluation interfaces with a minimum of change and minimum of cognitive friction. Beyond championing standard evaluation it attempts to introduce as few of its own opinions as possible.
A case in point is dplyr::rename()
/seplyr::rename_se()
. dplyr::rename()
is used as follows.
suppressPackageStartupMessages(library("dplyr")) datasets::mtcars %>% rename(cylinders = cyl, gears = gear) %>% head()
Notice dplyr::rename()
renamings are written as assignments making them very similar to dplyr::mutate()
. This is the reverse from how R
usually handles list or mapping structures.
In named vectors or named lists keys are written on the left and values are written on the right as follows.
mp <- c("cyl" = "cylinders", "gear" = "gears") print(mp)
Because seplyr
is intended to be a set of adapters for dplyr
we simply adopt dplyr::rename()
's convention. This allows the user to mechanically translate their experience and expectations from scripting over dplyr::rename()
to directly use seplyr::rename_se()
as follows.
library("seplyr") datasets::mtcars %.>% rename_se(., c("cylinders" := "cyl", "gears" := "gear")) %.>% head(.)
We hope this makes it easy to translate one-off analyses into re-usable scripts by incrementally replacing known variable names with parametric versions. The :=
operator is just a convenience function for building up maps, we could also have written rename_se(c("cylinders" = "cyl", "gears" = "gear"))
or passed in a named vector built up elsewhere.
rename_se
interprets all left-hand names as new column names and all right-hand names as old column names. This allows rename_se
to be used to swap columns:
data.frame(a = 1, b = 2) %.>% rename_se(., c('a', 'b') := c('b', 'a'))
Please see help("%.>%", package="wrapr")
for details on "dot pipe."
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.