Je veux trier un data.frame par plusieurs colonnes. Par exemple, avec le data.frame ci-dessous, je voudrais trier par la colonne z
(décroissante) puis par la colonne b
(croissante) :
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
Vous pouvez utiliser la fonction order()
directement sans avoir recours à des outils complémentaires -- voir cette réponse plus simple qui utilise une astuce dès le début du code 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
Edit quelques 2+ années plus tard: On vient de demander comment faire cela par index de colonne. La réponse est de simplement passer la ou les colonnes de tri souhaitées à la fonction 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>
plutôt que d'utiliser le nom de la colonne (et with()
pour un accès plus facile/plus direct).
Avec [cette fonction (très utile) de Kevin Wright][1], publiée dans la section des astuces du wiki R, cela est facile à réaliser.
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