R ffdf排序数据

时间:2013-07-22 12:16:57

标签: r

我想对数据进行排序

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对数据进行排序。如果我们有数据框,这是一项非常简单的任务。

感谢。

2 个答案:

答案 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), ]