首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >嵌套应用函数在tapply中

嵌套应用函数在tapply中
EN

Stack Overflow用户
提问于 2018-06-19 14:22:52
回答 1查看 386关注 0票数 1

我想使用tapply根据变量对函数的结果进行分组。我认为我需要传递给tapply的函数是,我相信,apply。我希望这个函数根据不同变量(var1)中存在的另一个值来赋值,但是如果var1的值是下一行(分组内)上的其他值,那么我想分配一个不同的值。这是我尝试过的,但不起作用。我不确定这是因为我的方法有问题还是因为我应用的函数不正确。

代码语言:javascript
复制
#example data
df.examp <- tibble(id = c(rep(1, 4), rep(2, 4), rep(3, 4)),
   var1 = c('a','a','b','b','a','a','a','a','b','b','b','b'))

#my attempt
df.examp$var2 <- tapply(df.examp$var1, df.examp$id,
                        apply(df.examp$var1, 1, function(j)
                          if (j == 'a'){
                            'foo'
                          } else if (j == 'a' & j + 1 == 'b'){
                            'bar'
                          } else {
                            'other'
                          }
                        )

)

代码语言:javascript
复制
#hoped for outcome
df.examp <- mutate(df.examp, var2 = c(rep('bar', 4), rep('foo', 4), rep('other', 4)))

有人知道这是怎么回事吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-06-19 14:41:39

我们可以在按'id‘分组后进行case_when

代码语言:javascript
复制
library(dplyr)
df.examp %>% 
  group_by(id) %>%
  mutate(var2 = case_when(any(var1 == 'a' & lead(var1) == 'b') ~ 'bar', 
         var1 == 'a' ~ 'foo', 
         TRUE ~ 'other'))
# A tibble: 12 x 3
# Groups:   id [3]
#      id var1  var2 
#   <dbl> <chr> <chr>
# 1     1 a     bar  
# 2     1 a     bar  
# 3     1 b     bar  
# 4     1 b     bar  
# 5     2 a     foo  
# 6     2 a     foo  
# 7     2 a     foo  
# 8     2 a     foo  
# 9     3 b     other
#10     3 b     other
#11     3 b     other
#12     3 b     other
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50930760

复制
相关文章

相似问题

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