自 R 實戰(zhàn) 1. 可以使用 order 函數(shù)對數(shù)據(jù)框排序,默認升序,在排序變量前加一個減號,即可得到降序排列。 data.frame[order(data.frame$a),] 在R中,和排序相關(guān)的函數(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]。下面是相關(guān)的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ù)可以直接利用,但是暫時還沒有找到,以后碰到牛銀再請求指點吧! |
|