我有一个包含列 x1, x2, group
的数据框,我想生成一个新的数据框,其中包含一个额外的列rank
,该列指示x1
在其组中的顺序。
这里有一个相关的问题(链接),但是已被接受的答案似乎不再起作用。
到此为止,没问题:
library(dplyr)
data(iris)
by_species <- iris %>%
arrange(Species, Sepal.Length) %>%
group_by(Species)
但是当我尝试通过分组获取排名时:
by_species <- mutate(by_species, rank=row_number())
错误提示为:
Error in rank(x, ties.method = "first", na.last = "keep") :
argument "x" is missing, with no default
更新
问题出在dplyr
和plyr
之间的一些冲突。要重现此错误,请同时加载两个软件包:
library(dplyr)
library(plyr)
data(iris)
by_species <- iris %>%
arrange(Species, Sepal.Length) %>%
group_by(Species) %>%
mutate(rank=row_number())
# Error in rank(x, ties.method = "first", na.last = "keep") :
# argument "x" is missing, with no default
卸载plyr
,它的表现与预期一样:
detach("package:plyr", unload=TRUE)
by_species <- iris %>%
arrange(Species, Sepal.Length) %>%
group_by(Species) %>%
mutate(rank=row_number())
by_species %>% filter(rank <= 3)
## Sepal.Length Sepal.Width Petal.Length Petal.Width Species rank
## (dbl) (dbl) (dbl) (dbl) (fctr) (int)
## 1 4.3 3.0 1.1 0.1 setosa 1
## 2 4.4 2.9 1.4 0.2 setosa 2
## 3 4.4 3.0 1.3 0.2 setosa 3
## 4 4.9 2.4 3.3 1.0 versicolor 1
## 5 5.0 2.0 3.5 1.0 versicolor 2
## 6 5.0 2.3 3.3 1.0 versicolor 3
## 7 4.9 2.5 4.5 1.7 virginica 1
## 8 5.6 2.8 4.9 2.0 virginica 2
## 9 5.7 2.5 5.0 2.0 virginica 3
by_species <- mutate(by_species, rank=row_number())
这个命令是产生错误的吗?它在我的电脑上可以运行,并且你的错误提到的是rank
函数,而不是正在使用的row_number
函数。此外,如果你使用rank
函数,你需要提供一个参数,比如rank(x)
(其中x
是你想排名的对象)。row_number
函数不需要这样做。 - stevebplyr
然后加载dplyr
在我的电脑上似乎无法工作。 - albertodetach("package:plyr", unload=TRUE)
。 - vb66