如何应用将带因子的data.frame返回到序列的函数?

例子:

s <- factor(c(10, 20, 30))
t <- factor(c("a", "b", "a"))
v <- c(5, 6, 4)

df <- data.frame(s,t,v)

所以data.frame df是这样的:
   s t v
1 10 a 5
2 20 b 6
3 30 a 4

我也有一个返回data.frame的函数:
simpleFunc2 <- function(df, x){
  tmp <- subset(df, df$s == x)
  return(tmp)
}

现在我有一个序列
x <- c(20, 30, 10, 30, 10)

并希望将函数simpleFunc2应用于此序列。

我用sapply
sapply(x, function(x) simpleFunc2(df, x))

但是我明白了
  [,1]     [,2]     [,3]     [,4]     [,5]
s factor,1 factor,1 factor,1 factor,1 factor,1
t factor,1 factor,1 factor,1 factor,1 factor,1
v 6        4        5        4        5

如何获得正确的因子值?

此示例已简化。因此,在这种情况下,也许有更简单的方法可以做到这一点。

最佳答案

尝试使用lapply代替do.call,如下所示:

do.call(rbind, lapply(x, function(x) simpleFunc2(df=df, x)))

关于r - 如何应用函数返回带因子的data.frames到序列,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/14186051/

10-12 20:25