为了从数据框中选择一些列,我可以这样做:
但是运行
require(dplyr)
require(magrittr)
df <- data.frame(col1=c(1, 2, 3), col2=letters[1:3], col3=LETTERS[4:6])
df %>%
select(col1, col2)
我想编写一个类似于以下函数的功能:
f <- function(data, firstCol, secondCol){
data %>%
select(substitute(firstCol), substitute(secondCol))
}
但是运行
f(df, col1, col2)
时会出现错误。Error in select_vars(names(.data), ..., env = parent.frame()) :
(list) object cannot be coerced to type 'double'
Called from: (function ()
{
.rs.breakOnError(TRUE)
})()
编辑——稍微复杂的例子:
假设我想要执行下面的操作:
mtcars %>%
select(cyl, hp) %>%
unique %>%
group_by(cyl) %>%
summarise(avgHP = mean(hp))
但使用不同的数据集和变量名时,我可以重用代码并替换mtcars
、cyl
和hp
。但我宁愿把所有内容都包装在一个函数中。