我想对数据进行排序
z=as.ffdf(data.frame(w=c(4,1,2,5,7,8,65,3,2,9), x=c(12,1,3,5,65,3,2,45,34,11),y=1:10))
我需要根据列w,x对数据进行排序。如果我们有数据框,这是一项非常简单的任务。
感谢。
答案 0 :(得分:3)
使用包ff中的ffdforder,这将返回一个ff_vector,您可以使用它来索引ffdf,而不会出现RAM问题。
require(ff)
z=as.ffdf(data.frame(w=c(4,1,2,5,7,8,65,3,2,9), x=c(12,1,3,5,65,3,2,45,34,11),y=1:10))
idx <- ffdforder(z[c("w","x")])
zordered <- z[idx, ]
zordered
答案 1 :(得分:0)
您可以尝试这样的事情
require(ffbase)
z <- as.ffdf(data.frame(w=c(4,1,2,5,7,8,65,3,2,9),
x=c(12,1,3,5,65,3,2,45,34,11),y=1:10))
z[order(z$w[], z$x[]), ]
## w x y
## 2 1 1 2
## 3 2 3 3
## 9 2 34 9
## 8 3 45 8
## 1 4 12 1
## 4 5 5 4
## 5 7 65 5
## 6 8 3 6
## 10 9 11 10
## 7 65 2 7
您可以使用fforder
在不使用内存的情况下订购ffdf
。归功于@jwijffels
z[fforder(z$w, z$x), ]