在dplyr中将参数用作列名称

在dplyr中将参数用作列名称,r,dplyr,nse,R,Dplyr,Nse,我正在努力混合使用参数和直接从数据帧引用列名。请帮助我更正第二个函数以返回与第一个函数相同的结果 install.packages("dplyr", version = "0.5.0")` library(dplyr) df <- data.frame(year = 2010:2015, GVA = 1:6) f <- function(df) { df %>% mutate(indexGVA = GVA/max(ifelse(year == 2010, GVA, 0

我正在努力混合使用参数和直接从数据帧引用列名。请帮助我更正第二个函数以返回与第一个函数相同的结果

install.packages("dplyr", version = "0.5.0")`
library(dplyr)

df <- data.frame(year = 2010:2015, GVA = 1:6)
f <- function(df) {
  df %>%
  mutate(indexGVA = GVA/max(ifelse(year == 2010, GVA, 0)) * 100)
}
f(df)

g <- function(df, val = NULL) {
  df %>%
  mutate_(indexGVA = ~val/max(ifelse(year == 2010, val, 0)) * 100)
}
g(df, val = "GVA")
install.packages(“dplyr”,version=“0.5.0”)`
图书馆(dplyr)

df
mutate
现在已被弃用(
?mutate
),您可以使用
enquo
rlang
引用和取消引用参数:

library(rlang)
g <- function(df, val = NULL) {
  val_quo = enquo(val)
  df %>%
    mutate(indexGVA = (!! val_quo)/max(ifelse(year == 2010, (!! val_quo), 0)) * 100)
}

g(df, val = GVA)

它为二进制运算符提供了错误:mutate_impl(.data,dots)中的错误:非数字参数
  year GVA indexGVA
1 2010   1      100
2 2011   2      200
3 2012   3      300
4 2013   4      400
5 2014   5      500
6 2015   6      600