我试图弄清楚如何对存储在列表中的组使用case_when,因此修改列表将修改case_when的结果。
下面是一个玩具测试用例:
library(tidyverse)
info <- tibble(target = letters[seq(1, 10)])
groups <- list("A" = letters[seq(1, 10, by = 3)],
"B" = letters[seq(2, 10, by = 3)],
"C" = letters[seq(3, 10, by = 3)])
info %>% mutate(case_when(
target %in% groups$A ~ names(groups)[1],
target %in% groups$B ~ names(groups)[2],
target %in% groups$C ~ names(groups)[3]
))这提供了我想要的输出,但我希望从列表中动态生成case_when中的选项。我想应该是这样的:
generate_cases <- function(x, i) {
### I have no idea what to do here...
}
cases <- groups %>% imap(generate_cases)
info %>% mutate(case_when(!!! cases))我怀疑有什么东西是使用了it ()和rlang::expr(),但我真的不知道如何将它串在一起。
发布于 2021-03-06 01:50:56
这里有一种使用purrr::imap函数的方法
cases <- imap(groups, ~quo(target %in% !!.x ~ !!.y))
info %>% mutate(case_when(
!!!cases
))一个更好的选择可能是将您的组重组到一个适当的查找表中,这样您就可以进行有效的左联接。一种方法是
info %>%
left_join(stack(groups), by=c("target"="values"))https://stackoverflow.com/questions/66501328
复制相似问题