首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将tapply函数转换为for循环?

如何将tapply函数转换为for循环?
EN

Stack Overflow用户
提问于 2020-03-02 01:43:49
回答 1查看 206关注 0票数 1

我有一个函数,它应该像tapply()那样工作,但我似乎无法正确地工作。我需要使用for循环这个。

代码语言:javascript
复制
baby.tapply = function(X, INDEX, FUN) {
  z = 0
 for(y in levels(factor(INDEX))){
   z = FUN(X)
 }
  return(z)
}

baby.tapply(X=mtcars$mpg, INDEX=mtcars$cyl, FUN=mean)

#Should mimic this: 
tapply(mtcars$mpg, mtcars$cyl, mean)

从哪里开始有什么建议吗?我的输出: 20.090625 1

正确输出(来自tapply) 4 6 8 26.66364 19.74286 15.10000

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-03-02 01:49:44

下面是用tapply循环模拟for的一种方法:

代码语言:javascript
复制
baby.tapply = function(X, INDEX, FUN) {

  lvls <- levels(factor(INDEX))
   z <- numeric(length(lvls))
   for(y in seq_along(lvls)){
       z[y] = FUN(X[INDEX == lvls[y]])
    }
    return(setNames(z, lvls))
}

baby.tapply(X=mtcars$mpg, INDEX=mtcars$cyl, FUN=mean)
#      4        6        8 
#26.66364 19.74286 15.10000 

#Comparing with the output of tapply
tapply(mtcars$mpg, mtcars$cyl, mean)
#       4        6        8 
#26.66364 19.74286 15.10000 

正如@Onyambu所提到的,最好将z初始化为list而不是向量

代码语言:javascript
复制
z <- vector("list",length(lvls))

对于返回两个值的函数(如range )。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60481527

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档