Szeretnék egy data.frame-et több oszlop szerint rendezni. Például az alábbi data.frame esetében a "z" oszlop (csökkenő), majd a "b" oszlop (növekvő) szerint szeretnék rendezni:
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
A order()
függvényt közvetlenül is használhatod anélkül, hogy kiegészítő eszközökhöz kellene folyamodnod -- lásd ezt az egyszerűbb választ, amely egy trükköt használ közvetlenül a example(order)
kód tetején:
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
Szerkesztés kb. 2+ évvel később: Épp most kérdezték, hogy hogyan lehet ezt oszlopindex szerint csinálni. A válasz az, hogy egyszerűen át kell adni a kívánt rendezési oszlop(ok)at a order()
függvénynek:
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>
ahelyett, hogy az oszlop nevét használnánk (és a with()
-t a könnyebb/közvetlenebb hozzáférés érdekében).
Az R wiki tippek szekciójában közzétett Kevin Wright által készített (nagyon hasznos) funkcióval ez könnyen megvalósítható.
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
Alternatívaként a Deducer csomag használatával
library(Deducer)
dd<- sortData(dd,c("z","b"),increasing= c(FALSE,TRUE))