嘿,我正在尝试通过使用新版本的 dplyr 添加“Last”来重命名某些列,但我不断收到此错误
Error: `across()` must only be used inside dplyr verbs.
这是我的代码
data %>% rename(across(everything(), ~paste0("Last_", .)))
dplyr版本:v1.0.2
我们可以用rename_with
代替rename
library(dplyr)
library(stringr)
data %>%
rename_with(~str_c("Last_", .), everything())
可重现的例子
data(iris)
head(iris) %>%
rename_with(~str_c("Last_", .), .cols = everything())
# Last_Sepal.Length Last_Sepal.Width Last_Petal.Length Last_Petal.Width Last_Species
#1 5.1 3.5 1.4 0.2 setosa
#2 4.9 3.0 1.4 0.2 setosa
#3 4.7 3.2 1.3 0.2 setosa
#4 4.6 3.1 1.5 0.2 setosa
#5 5.0 3.6 1.4 0.2 setosa
#6 5.4 3.9 1.7 0.4 setosa
根据?rename
rename() 使用 new_name = old_name 语法更改各个变量的名称; rename_with() 使用函数重命名列。
and in ?across
across() 可以轻松地将相同的转换应用于多个
列,允许您在 summarise() 中使用 select() 语义
和变异()。
描述说它的用途mutate/summarise
(and transmute
?),并且没有任何其他功能的使用指示,即它会失败select
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)