按照列表对数据框的一列进行排序,然后再根据另一列进行排序。

4

I have the following data frame:

tdf <- structure(list(GO = c("Cytokine-cytokine receptor interaction", 
"Cytokine-cytokine receptor interaction|Endocytosis", "I-kappaB kinase/NF-kappaB signaling", 
"NF-kappa B signaling pathway", "NF-kappaB import into nucleus", 
"T cell chemotaxis"), PosCount = c(17, 18, 4, 5, 1, 2), shortgo = structure(c(1L, 
1L, 2L, 2L, 2L, 3L), .Label = c("z", "X", "y"), class = "factor")), .Names = c("GO", 
"PosCount", "shortgo"), row.names = c(NA, 6L), class = "data.frame")
desired_order <- c("y", "X", "z")

看起来像这样:

                                                  GO PosCount shortgo
1             Cytokine-cytokine receptor interaction       17       z
2 Cytokine-cytokine receptor interaction|Endocytosis       18       z
3                I-kappaB kinase/NF-kappaB signaling        4       X
4                       NF-kappa B signaling pathway        5       X
5                      NF-kappaB import into nucleus        1       X
6                                  T cell chemotaxis        2       y

我想做的是使用预定义列表对 shortgo 进行排序。
desired_order <- c("y", "X", "z")

然后对于每个shortgo组内部按PosCount排序。结果如下:

                                                 GO PosCount shortgo
                                  T cell chemotaxis        2       y
                       NF-kappa B signaling pathway        5       X
                I-kappaB kinase/NF-kappaB signaling        4       X
                      NF-kappaB import into nucleus        1       X
 Cytokine-cytokine receptor interaction|Endocytosis       18       z
             Cytokine-cytokine receptor interaction       17       z

我尝试过,但失败了:

library(dplyr)
#tdf %>% arrange(as.character(shortgo), desc(PosCount))
tdf %>% arrange(desired_order, desc(PosCount))

应该如何正确地做呢?

1个回答

6
使用变量的factor表示来实现您想要的order
dplyr中,只需执行:
tdf %>% arrange(factor(shortgo,levels=desired_order), desc(PosCount) )

在基本的 R 中,只需要使用以下代码:
tdf[order(factor(tdf$shortgo,levels=desired_order), -tdf$PosCount),]

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接