我正在尝试将col与数据中的col_new进行比较,并创建一个名为change_col的新布尔标识符来标识更改。
下面是一个例子:
input <- data.frame(
apple = c(1,2)
,apple_new = c(2,3)
,banana = c(1,2)
,banana_new = c(1,3)
)
desired_output <- data.frame(
apple = c(1,2)
,apple_new = c(2,3)
,change_apple = c(TRUE,TRUE)
,banana = c(1,2)
,banana_new = c(1,3)
,change_banana = c(FALSE,TRUE)
)
我正在考虑使用 mutate 和 cross 来遍历苹果和香蕉,但有点失败......有人有更好的主意吗?
library(dplyr)
var_to_consider <- c('apple','banana')
input %>%
mutate( across(c(var_to_consider),
.fns = list(change = ~ . != !!sym(paste0(.,'_new') )),
.names = "{fn}_{col}" ) )
以上将导致以下错误:
Error: Only strings can be converted to symbols