我正在创建一个工作流,其中包含相同的管道步骤,包括重命名、选择、然后使用我在管道之前提供的名称进行变异。
我已经成功使用enquo()
and !!
(bang bang) 重命名为我想要的字符串,然后再次选择它,但是当我到达 mutate 步骤时,它要么将文本字符串重复为列值,要么不会评估。
我重新创建了以下代码:
#Testing rename, select, and mutate use cases for enquo()
#Load packages
library(dplyr)
library(rlang)
library(magrittr)
#Create name I want to pass
new_var <- quo("new_name")
#Create Test Data
t1 <- tibble(Year = c(2000:2004),
old_name = c(NA, 1, 1, 1, NA))
quo_name()
我可以用和重命名列:=
t1 %>%
rename( !! quo_name(new_var) := old_name)
我可以选择它使用!!
t1 %>%
rename( !! quo_name(new_var) := old_name) %>%
select(Year, !!new_var)
但是我不能在 mutate 中调用该列并使用这些值
t1 %>%
rename( !! quo_name(new_var) := old_name) %>%
select(Year, !!new_var) %>%
mutate(test_var = (!! new_var))