Como ordenar um quadro de dados por múltiplas colunas

Eu quero ordenar um data.frame por várias colunas. Por exemplo, com o data.frame abaixo eu gostaria de ordenar por coluna z (descendente) e depois por coluna 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
Solução

Você pode utilizar a função order() diretamente sem recorrer a ferramentas adicionais -- veja esta resposta mais simples que utiliza um truque direto do topo do código 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 cerca de 2+ anos depois: Foi apenas perguntado como fazer isto por índice de colunas. A resposta é simplesmente passar a(s) coluna(s) de ordenação desejada(s) para a função ordem():

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> 

ao invés de utilizar o nome da coluna (e with() para acesso mais fácil/mais direto).

Comentários (10)

Com esta (muito útil) função de Kevin Wright, postada na seção de dicas do wiki R, isto é facilmente alcançado.

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
Comentários (1)

Alternativamente, usando o pacote Dedutor


library(Deducer)
dd
Comentários (0)