在 tapply 中嵌套应用函数
Nest apply function within tapply
我想使用 tapply
根据变量对函数的结果进行分组。我认为我需要传递给 tapply
的函数是 apply
。我希望此函数根据不同变量 (var1
) 中另一个值的存在来分配一个值,但是如果 var1
的值是下一行(在分组内)的其他值,则我想分配一个不同的值。这是我尝试过的方法,但它不起作用。我不确定那是因为我的方法有问题还是因为我应用的功能不正确。
#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'
}
)
)
#hoped for outcome
df.examp <- mutate(df.examp, var2 = c(rep('bar', 4), rep('foo', 4), rep('other', 4)))
有没有人知道哪里出了问题?
按 'id'
分组后我们可以 case_when
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
我想使用 tapply
根据变量对函数的结果进行分组。我认为我需要传递给 tapply
的函数是 apply
。我希望此函数根据不同变量 (var1
) 中另一个值的存在来分配一个值,但是如果 var1
的值是下一行(在分组内)的其他值,则我想分配一个不同的值。这是我尝试过的方法,但它不起作用。我不确定那是因为我的方法有问题还是因为我应用的功能不正确。
#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'
}
)
)
#hoped for outcome
df.examp <- mutate(df.examp, var2 = c(rep('bar', 4), rep('foo', 4), rep('other', 4)))
有没有人知道哪里出了问题?
按 'id'
分组后我们可以case_when
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