考虑以下示例
> library(forcats)
> library(dplyr)
>
>
> dataframe <- data_frame(var = c(1,1,1,2,3,4),
+ var2 = c(10,9,8,7,6,5))
> dataframe
# A tibble: 6 x 2
var var2
<dbl> <dbl>
1 1.00 10.0
2 1.00 9.00
3 1.00 8.00
4 2.00 7.00
5 3.00 6.00
6 4.00 5.00
我创建了一个因子变量
> dataframe <- dataframe %>% mutate(myfactor = factor(var))
>
> dataframe$myfactor
[1] 1 1 1 2 3 4
Levels: 1 2 3 4
我不明白根据在因子级别完成的一些其他计算来重新排序这个因子的正确语法(和逻辑)是什么。
例如,我想根据递减的值重新排序我的因子
> data_rank <- dataframe %>% group_by(myfactor) %>% summarise(rank_var = mean(var2))
> data_rank
# A tibble: 4 x 2
myfactor rank_var
<fct> <dbl>
1 1 9.00
2 2 7.00
3 3 6.00
4 4 5.00
所以 4 将是第一,3 将是第二,等等。
这样做的语法是fct_reorder
什么,它背后的逻辑是什么?
谢谢!