2017-08-26 37 views
1

使用foo(c("b"))调用以下函数。输出显示为内联。为什么表达式的LHS中的`rlang :: sym`和`rlang :: quo_name`的行为类似?

我很困惑,为什么(1)df %>% mutate(!!x_ := 100 + !!x))和(2)df %>% mutate(!!x := 100 + !!x))工作原理相同;基于dplyr programming recipes只有(1)应该工作。

foo <- function(variables) { 

    x <- rlang::sym(variables[[1]]) 

    x_ <- quo_name(x) 

    print(x) 
    #> b 

    print(typeof(x)) 
    #> [1] "symbol" 

    print(x_) 
    #> [1] "b" 

    print(typeof(x_)) 
    #> [1] "character" 

    df <- data_frame(a = 1, b = 2) 

    print(df %>% mutate(!!x_ := 100 + !!x)) 

    #> # A tibble: 1 x 2 
    #>   a  b 
    #>  <dbl> <dbl> 
    #> 1  1 102 

    print(df %>% mutate(!!x := 100 + !!x)) 

    #> # A tibble: 1 x 2 
    #>   a  b 
    #>  <dbl> <dbl> 
    #> 1  1 102 

} 
+1

根据[documentation](http://dplyr.tidyverse.org/articles/programming.html#setting-variable-names)中提到的,你指的是:* LHS的规则略有不同:未加引号的操作数应计算为字符串或符号*。它工作是因为'x_'是一个字符。 –

+1

你是对的!我错过了“......或符号”部分。如果将评论移至答案,我可以继续并接受。 – Shantanu

回答

3

将注释移至答案。

按在documentation你指的是提到:

LHS的规则略有不同:未加引号操作 应计算为字符串或符号

这里,它的工作原理是因为x_实际上是一个字符。

相关问题