簡體   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