data.frameを複数の列でソートしたいのですが。例えば、以下のデータフレームでは、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>
その答えは,列の名前を使うのではなく,{{5975295}}というように,単純にorder()
関数に渡すことです。
R wikiのtipsセクションに掲載されているKevin Wright氏によるこの(非常に役立つ)関数を使えば、これを簡単に実現できます。
sort(dd,by = ~ -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