带矢量输入的Dplyr条件列ifelse

Nic*_*ick 0 r dplyr nse rlang

我正在尝试使用dplyr的新NSE语言方法来创建条件变异,使用矢量输入.我遇到麻烦的地方是将列设置为等于它自己,请参见下面的mwe:

df <- data.frame("Name" = c(rep("A", 3), rep("B", 3), rep("C", 4)), 
                 "X" = runif(1:10), 
                 "Y" = runif(1:10)) %>% 
    tbl_df() %>% 
    mutate_if(is.factor, as.character)

ColToChange <- "Name"
ToChangeTo <- "Big"
Run Code Online (Sandbox Code Playgroud)

现在,使用以下内容:

df %>% mutate( !!ColToChange := ifelse(X >= 0.5 & Y >= 0.5, ToChangeTo, !!ColToChange))
Run Code Online (Sandbox Code Playgroud)

ColToChange值设置为Name,而不是回到其原始值.我因此尝试使用上面的语法来实现这一点:

df %>% mutate( !!ColToChange := ifelse(X >= 0.5 & Y >= 0.5, ToChangeTo, Name))
Run Code Online (Sandbox Code Playgroud)

但不是Name,它是矢量.

Psi*_*dom 5

您需要首先使用rlang:sym评估ColToChange作为符号Name,然后将其评估为列!!:

library(rlang); library(dplyr);

df %>% mutate(!!ColToChange := ifelse(X >= 0.5 & Y >= 0.5, ToChangeTo, !!sym(ColToChange)))

# A tibble: 10 x 3
#    Name          X         Y
#   <chr>      <dbl>     <dbl>
# 1     A 0.05593119 0.3586310
# 2     A 0.70024660 0.4258297
# 3   Big 0.95444388 0.7152358
# 4     B 0.45809482 0.5256475
# 5   Big 0.71348123 0.5114379
# 6     B 0.80382633 0.2665391
# 7   Big 0.99618062 0.5788778
# 8   Big 0.76520307 0.6558515
# 9     C 0.63928001 0.1972674
#10     C 0.29963517 0.5855646
Run Code Online (Sandbox Code Playgroud)