Quiero ordenar un data.frame por múltiples columnas. Por ejemplo, con el data.frame de abajo me gustaría ordenar por la columna z
(descendente) y luego por la columna 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
Puede utilizar la función order()
directamente sin tener que recurrir a herramientas complementarias -- vea esta respuesta más sencilla que utiliza un truco desde la parte superior del código de 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
Editar unos 2+ años después: Se acaba de preguntar cómo hacer esto por índice de columna. La respuesta es simplemente pasar la(s) columna(s) de ordenación deseada(s) a la función 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>
en lugar de utilizar el nombre de la columna (y with()
para un acceso más fácil/ directo).
Con esta función (muy útil) de Kevin Wright, publicada en la sección de consejos de la wiki de R, esto se consigue fácilmente.
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