列単位でデータフレームをソートする方法は?[R]

このエントリーをはてなブックマークに追加

質問:

僕は複数の列で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

By Christopher DuBois | 質問日時: 2009年8月18日 21:33



回答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

同じことを列に対してやろうとするなら、ソートしたい列を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()でやると簡単だと思うけど).

By Dirk Eddelbuettel | 回答日時: 2009年8月18日 21:51



回答2:

君のチョイスはいくつかある:

  • baseorder
  • dplyrarrange
  • data.tablesetordersetorderv
  • plyrarrange
  • taRifxsort
  • doByorderBy
  • DeducersortData

たいていの場合、ライブラリを使っちゃいけない場合とかを除いてdplyrdata.tableを使うべきだと思う。もしその場合だったら、base :: orderを使えばいい。

By Ari B. Friedman | 回答日時: 2011年7月29日 10:48



回答3:

他の人がすばらしい答えをしてるけど、個人的にはdplyrが僕がすぐに、そして簡単に覚えられた構文を使ってる(だからよく使う)。

library(dplyr)
# sort mtcars by mpg, ascending... use desc(mpg) for descending
arrange(mtcars, mpg)
# sort mtcars first by mpg, then by cyl, then by wt)
arrange(mtcars , mpg, cyl, wt)

OPの問題については:

arrange(dd, desc(z), b)
b x y z
1 Low C 9 2
2 Med D 3 1
3 Hi A 8 1
4 Hi A 9 1

By Ben | 回答日時: 2014年2月18日 21:29



Source: How to sort a dataframe by column(s)?

共有 コメント