我想按多列对 data.frame 进行排序。例如,对于下面的 data.frame,我想按列 z(降序)然后按列 b(升序)排序:

dd <- data.frame(b = factor(c("Hi", "Med", "Hi", "Low"),
      levels = c("Low", "Med", "Hi"), ordered = TRUE),
      x = c("A", "D", "A", "C"), y = c(8, 3, 9, 9),
      z = c(1, 1, 1, 2))
dd
    b x y z
1  Hi A 8 1
2 Med D 3 1
3  Hi A 9 1
4 Low C 9 2

最佳答案

您可以直接使用 order() 函数,而无需借助附加工具——请参阅这个更简单的答案,它使用了 example(order) 代码顶部的一个技巧:

R> dd[with(dd, order(-z, b)), ]
    b x y z
4 Low C 9 2
2 Med D 3 1
1  Hi A 8 1
3  Hi A 9 1

大约 2 年后编辑:只是被问到如何通过列索引来做到这一点。答案是简单地将所需的排序列传递给 order() 函数:
R> dd[order(-dd[,4], dd[,1]), ]
    b x y z
4 Low C 9 2
2 Med D 3 1
1  Hi A 8 1
3  Hi A 9 1
R>

而不是使用列的名称(和 with() 以便更容易/更直接地访问)。

关于r - 如何按多列对数据框进行排序,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/1296646/

10-13 22:40