Diyelim ben şu var ki data.table
içinde R
:
library(data.table)
DT = data.table(x=rep(c("b","a","c"),each=3), y=c(1,3,6), v=1:9)
İki sütuna göre sıralamak istiyorum (sütunlar x
ve diyelim v
). Bunu kullandım:
DT[order(x,v)] # sorts first by x then by v (both in ascending order)
Ama şimdi, onu x
(azalan sırayla) sıralamak ve aşağıdaki koda sahip olmak istiyorum:
DT[order(-x)] #Error in -x : invalid argument to unary operator
Bu nedenle, bu hatanın bundan kaynaklandığını düşünüyorum class(DT$x)=character
. Bu sorunu çözmek için bana herhangi bir öneri verebilir misiniz?
Kullanabileceğimi biliyorum DT[order(x,decreasing=TRUE)]
, ancak aynı anda her iki yolu kullanarak (bazıları azalıyor, bazıları artıyor) birkaç sütuna göre sıralamak için sözdizimini bilmek istiyorum.
Sonucu kullanırsanız sorun olmadığını DT[order(-y,v)]
, ancak kullanırsanız DT[order(-x,v)]
bir hata olduğunu unutmayın. Öyleyse sorum şu: bu hatayı nasıl çözebilirim?
DT[order(-x)]
, eşdeğer bir ifade değil setorder(DT, -x)
çünkü setorder()
aslında hareket DT
ederken diğeri davranmıyor. Eşdeğer ifadeler DT <- DT [order (-x)] setorder (DT, -x) olacaktır.