Come ordinare un dataframe per più colonne

Voglio ordinare un data.frame per più colonne. Per esempio, con il data.frame qui sotto vorrei ordinare per colonna z (discendente) poi per colonna b (ascendente):

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
Soluzione

Puoi usare la funzione ordine() direttamente senza ricorrere a strumenti aggiuntivi -- vedi questa risposta più semplice che usa un trucco direttamente dall'inizio del codice esempio(ordine):

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

Modifica circa 2+ anni dopo: È stato appena chiesto come fare questo per indice di colonna. La risposta è semplicemente passare la colonna o le colonne di ordinamento desiderate alla funzione 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> 

piuttosto che usare il nome della colonna (e con() per un accesso più facile/diretto).

Commentari (10)

Con questa funzione (molto utile) di Kevin Wright, postata nella sezione consigli del wiki di R, questo si ottiene facilmente.

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

In alternativa, usando il pacchetto Deducer


library(Deducer)
dd
Commentari (0)