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
1263
3
Puoi usare la funzione
ordine()
direttamente senza ricorrere a strumenti aggiuntivi -- vedi questa risposta più semplice che usa un trucco direttamente dall'inizio del codiceesempio(ordine)
: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()
:piuttosto che usare il nome della colonna (e
con()
per un accesso più facile/diretto).Con questa funzione (molto utile) di Kevin Wright, postata nella sezione consigli del wiki di R, questo si ottiene facilmente.
In alternativa, usando il pacchetto Deducer