複数の列でデータフレームの行を並べ替える(順序付ける) 質問する

複数の列でデータフレームの行を並べ替える(順序付ける) 質問する

データ フレームを複数の列で並べ替えたいです。たとえば、以下のデータ フレームでは、列 '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

ベストアンサー1

あなたは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()より簡単かつ直接的なアクセスのため)。

おすすめ記事