我想按多列对数据框进行排序。例如,对于下面的数据框,我想按列“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)代码顶部的技巧:
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()更容易/更直接的访问)。
with()