繁体   English   中英

按R中的ALL列对数据框进行排序

[英]Sort dataframe by ALL columns in R

对于具有任意列数的任意矩阵或数据框x ,我想这样做:

x=x[order(x[,1], x[,2], ..., x[,ncol(x)]),]

也就是说,我想按第一列,然后按第二列,...,然后按最后一列排序。 分拣扩展的讨论在这里似乎并没有包含解决方案。 这是我的解决方案,违反了fortune(106)

sortarray = function(x){
    k = ncol(x)
    com = paste("x = x[order(x[,", paste(1:k, collapse = "],x[,"), "]),]", sep = "")
    eval(parse(text = com))
    return(x)}

x = sortarray(x)

这似乎工作正常,但是没有更干净的方法吗?

编辑重复数据删除说明:这个问题在重要的方面(至少对我而言)与建议的重复有所不同。 上一个问题处理的情况是您明确声明要作为排序依据的列。 就我而言,我希望自动选择列(特别是所有列),而不必在命令命令中键入每个列的名称。 下面的答案解决了我的问题,这与上一个问题的答案不同。

x[do.call(order, x), ]

尝试执行

example(order)

在R提示符下。

先前在这里提出的问题:

如何按列对数据框排序?

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM