The R
package seplyr
supplies improved standard evaluation interfaces for some common dplyr
data plying tasks.
This project is used in production to avoid exposing all of the details of rlang
at the user level, and a demonstration of what can be done through value-oriented programming. Alternately one could use another value-oriented data manipulation system ‘rquery’/‘rqdatatable’.
To get started we suggest visiting the seplyr
site, and checking out some examples.
One quick example:
# Assume this is set elsewhere,
# supplied by a user, function argument, or control file.
orderTerms <- c('cyl', 'desc(gear)')
# load packages
library("seplyr")
# Loading required package: wrapr
# where we are actually working (perhaps in a re-usable
# script or function)
datasets::mtcars %.>%
arrange_se(., orderTerms) %.>%
head(.)
# mpg cyl disp hp drat wt qsec vs am gear carb
# Porsche 914-2 26.0 4 120.3 91 4.43 2.140 16.70 0 1 5 2
# Lotus Europa 30.4 4 95.1 113 3.77 1.513 16.90 1 1 5 2
# Datsun 710 22.8 4 108.0 93 3.85 2.320 18.61 1 1 4 1
# Merc 240D 24.4 4 146.7 62 3.69 3.190 20.00 1 0 4 2
# Merc 230 22.8 4 140.8 95 3.92 3.150 22.90 1 0 4 2
# Fiat 128 32.4 4 78.7 66 4.08 2.200 19.47 1 1 4 1
The concept is: in writing re-usable code or scripts you pretend you do not know the actual column names you will be asked to work with (that these will be supplied as values later at analysis time). This forces you to write scripts that can be used even if data changes, and are re-usable on new data you did not know about when writing the script.
To install this package please either install from CRAN with:
install.packages('seplyr')
Please see help("%.>%", package="wrapr")
for details on “dot pipe.”
In addition to standard interface adapters seplyr
supplies some non-trivial statement transforms: