1. ホーム
  2. r

[解決済み] データフレームの行を複数の列でソート(並び替え)する。

2022-03-15 19:48:34

質問

データフレームを複数の列で並べ替えたいのですが、どうすればいいですか?例えば、以下のデータフレームで、列 '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() を使えば、より簡単に、より直接的にアクセスすることができます。)