自 R 實戰(zhàn) 1. 可以使用 order 函數(shù)對數(shù)據(jù)框排序,,默認升序,,在排序變量前加一個減號,即可得到降序排列,。 data.frame[order(data.frame$a),] 在R中,,和排序相關的函數(shù)主要有三個:sort(),rank(),,order(),。 下面以一小段R代碼來舉例說明: > x<-c(97,93,85,74,32,100,99,67) > sort(x) [1] > order(x) [1] 5 8 4 3 2 1 7 6 > rank(x) [1] 6 5 4 3 1 8 7 2 假設x為一組學生完成某項測試所花費的時間(所用時間越短,,排名越靠前),rank()的返回值是這組學生所對應的排名,,而order()的返回值是各個排名的學生成績所在向量中的位置,。 前一段同學問我一個問題,如何返回一個數(shù)值向量中滿足某條件的元素在向量中的位置,?舉例來說,,x<-c(97,93,85,74,32,100,99,67),希望返回x中滿足值大于50且小于90的元素在向量x中的下標,。當時想了想,,沒覺得有什么好的方法,,使用了比較繁瑣的語句 sort(x,index.return=TRUE)[[2]][sort(x,index.return=TRUE)[[1]]<90&sort(x,index.return=TRUE)[[1]]>50],后來發(fā)現(xiàn)sort(x,index.return=TRUE)[[2]]和order(x)的返回值是一樣的,,而sort(x,index.return=TRUE)[[1]]和sort(x)的返回值是相同的,,因此語句可以簡化為order(x)[sort(x)>50&sort(x)<90]。下面是相關的R代碼: > x [1] > sort(x,index.return=TRUE)[[2]][sort(x,index.return=TRUE)[[1]]<90&sort(x,index.return=TRUE)[[1]]>50] [1] 8 4 3 > order(x)[sort(x)>50&sort(x)<90] [1] 8 4 3 > sort(x,index.return=TRUE) $x [1] $ix [1] 5 8 4 3 2 1 7 6 > order(x) [1] 5 8 4 3 2 1 7 6 或許還有更加方便的方法,,比如R中有簡單的函數(shù)可以直接利用,但是暫時還沒有找到,,以后碰到牛銀再請求指點吧,! |
|