Bir veri çerçevesini birden çok sütuna göre sıralama

Bir data.frame'i birden çok sütuna göre sıralamak istiyorum. Örneğin, aşağıdaki data.frame ile z sütununa (azalan) ve ardından b sütununa (artan) göre sıralamak istiyorum:

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
Çözüm

Eklenti araçlarına başvurmadan order() işlevini doğrudan kullanabilirsiniz -- doğrudan example(order) kodunun üst kısmındaki bir hileyi kullanan bu daha basit yanıta bakın:

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

Yaklaşık 2+ yıl sonra düzenleyin: Bunun sütun dizinine göre nasıl yapılacağı soruldu. Cevap, istenen sıralama sütun(lar)ını order() fonksiyonuna aktarmaktır:

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> 

sütunun adını kullanmak yerine (ve daha kolay/doğrudan erişim için with()).

Yorumlar (10)

R wiki'nin ipuçları bölümünde yayınlanan Kevin Wright'ın bu (çok yararlı) işlevi ile bu kolayca gerçekleştirilebilir.

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
Yorumlar (1)

Alternatif olarak, Deducer paketini kullanarak


library(Deducer)
dd
Yorumlar (0)