r - 按多列对数据框行进行排序(排序)

标签 r sorting dataframe r-faq

我想按多列对数据框进行排序。例如,对于下面的数据框,我想按列“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/

相关文章:

r - 如何使用 R 中的 kableExtra::kable() 函数在标题中正确显示脚注标记

c++ - 排序多维 vector

java - 在 java 中,如果仅移动最后一个数字项,则对整数数组进行排序的最佳方法是什么?

python - 根据条件替换列中的值,然后返回数据帧

r - 如何使用 ggplot2 隐藏图例的部分?

r - 带替换件的快速排序样本

c++ - 按 'enveloping' 或 'dominance' 标准排序坐标

Python3.7 Pandas1.0.1 Dataframe - 计算范围内的列总和并重新组合为一个新行?

R - 如何替换数据框中的部分变量字符串

r - `*tmp*` [[k]] : subscript out of bounds in R 中的错误