- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
与Tidy evaluation programming with dplyr::case_when有些相关和 Making tidyeval function inside case_when ,我想创建字符串(使用 Shiny 的应用程序)稍后在 case_when
函数中进行解析。这是一个例子:
library(tidyverse)
# simulated shiny inputs
new_column = sym("COL_NAME")
number_of_categories = 3
col1_text = "Big"
col1_min = 7.0
col1_max = 8.0
col2_text = "Medium"
col2_min = 5.0
col2_max = 6.9
col3_text = "Small"
col3_max = 4.9
col3_min = 4.0
columninput = sym("Sepal.Length")
iris %>%
mutate(new_column =
case_when(
!!columninput >= col1_min & !!columninput <= col1_max ~ col1_text,
!!columninput >= col2_min & !!columninput <= col2_max ~ col2_text,
!!columninput >= col3_min & !!columninput <= col3_max ~ col3_text
)
)
因为函数之间唯一改变的是索引,我想我们可以使用通用模式来创建一个字符串
# create single string
my_string <-function(i) {
paste0("!!", columninput, " >= col", i, "_min & ", "!!", columninput, " <= col", i, "_max ~ col", i, "_text")
}
然后为动态案例数重复字符串
mega_string <- map_chr(1:number_of_categories, ~ my_string(.x))
这是我无法完全拼凑的部分:使用这些字符串作为 case_when
中的参数。
# evaluate somehow?
iris %>%
mutate(
new_column = case_when(
# tidyeval mega_string?
paste(mega_string, collapse = "," )
)
)
这是正确的方法吗?您还会如何解决这个问题 - 非常感谢任何高级别或其他方面的帮助!
最佳答案
我们可以创建一个表达式并求值
library(dplyr)
library(stringr)
iris %>%
mutate(new_column = eval(rlang::parse_expr(str_c('case_when(',
str_c(mega_string, collapse=","), ')'))))
# Sepal.Length Sepal.Width Petal.Length Petal.Width Species new_column
#1 5.1 3.5 1.4 0.2 setosa Medium
#2 4.9 3.0 1.4 0.2 setosa Small
#3 4.7 3.2 1.3 0.2 setosa Small
#4 4.6 3.1 1.5 0.2 setosa Small
#5 5.0 3.6 1.4 0.2 setosa Medium
#6 5.4 3.9 1.7 0.4 setosa Medium
#7 4.6 3.4 1.4 0.3 setosa Small
#8 5.0 3.4 1.5 0.2 setosa Medium
#9 4.4 2.9 1.4 0.2 setosa Small
#10 4.9 3.1 1.5 0.1 setosa Small
# ...
或者使用 parse_expr
和 !!!
library(purrr)
iris %>%
mutate(new_column = case_when(!!! map(mega_string, rlang::parse_expr)))
# Sepal.Length Sepal.Width Petal.Length Petal.Width Species new_column
#1 5.1 3.5 1.4 0.2 setosa Medium
#2 4.9 3.0 1.4 0.2 setosa Small
#3 4.7 3.2 1.3 0.2 setosa Small
#4 4.6 3.1 1.5 0.2 setosa Small
#5 5.0 3.6 1.4 0.2 setosa Medium
#6 5.4 3.9 1.7 0.4 setosa Medium
#7 4.6 3.4 1.4 0.3 setosa Small
#8 5.0 3.4 1.5 0.2 setosa Medium
#...
关于r - Tidyeval 评估 case_when,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61601797/
假设我有两个函数,我想将 a 嵌套在 b 中: library(dplyr) library(rlang) a % head() Sepal.Length Sepal.Width Petal.Le
我想使用 dplyr >= 0.7 删除列向量 library(dplyr) data(mtcars) rem_cols % select(-one_of(rem_cols)) 关于以
我正在尝试创建一个将列名称列表传递给 dplyr 函数的函数。如果列名称列表以 ... 形式给出,我知道如何执行此操作,如 tidyeval 文档中所述: df % group_by(!!!g
我正在尝试创建一个将列名称列表传递给 dplyr 函数的函数。如果列名称列表以 ... 形式给出,我知道如何执行此操作,如 tidyeval 文档中所述: df % group_by(!!!g
我有一个 tibble 列 foo 包含 tibble 中另一列的名称。我想根据 foo 中命名的列进行过滤: mtcars %>% mutate(foo = c(rep("carb", 16),
我在 R 中有一个简单的函数,... 使用 tidyeval。是否可以将这些更改为字符串? simple_paste % paste(collapse="_x_") } si
如果我想明确覆盖范围,我可以使用 .data像这样的代词 library(dplyr) cyl # A tibble: 32 x 1 #> cyl_plus_one #>
我正在尝试包装 dplyr::filter在一个函数中,当有多个时 filter条件,然后它们作为向量或列表传递。请参阅此最小示例: filter_wrap 5) obtained 5) stop
与Tidy evaluation programming with dplyr::case_when有些相关和 Making tidyeval function inside case_when ,我
我正在使用 tidyeval 编写一个简单的函数,我需要将参数传递给公式接口(interface)。虽然我已经设法构建了该函数的工作版本,但它似乎不适用于 for 循环。 函数 foo Bayes
我正在尝试使用 tidyeval 进行编程。 我想编写一个函数来为选定的结果变量运行逻辑回归模型: library(tidyverse) set.seed(1234) df 如果我们还需要使用tid
考虑这个简单的例子 library(dplyr) dataframe dataframe # A tibble: 4 x 3 id group value 1 1
最新版本的 dplyr 不推荐使用下划线版本的函数,例如 filter_,转而使用 tidy evaluation . 新方式下划线形式的新形式是什么?如何使用 R CMD 检查来避免 undefin
我们可以定义一个使用动态列名的函数,然后在map中使用它。请注意 ListCol 中的 tibbles 如何具有列名称 a 和 b(取自原始文件中的 Letter 列)蒂 bool 。 library
接上较早的话题,( Use string as filter in dplyr? ),新的 tidyeval 会是什么?对此的回答是,因为 filter_ 已被弃用。 有没有办法在 dplyr 中使用
library(tidyverse) set.seed(1) graph.data 1 2009-10-14 4.87 2 2009-10-15 8.
所以这个例子基本上来自https://tidyeval.tidyverse.org/dplyr.html#patterns-for-single-arguments它工作得很好: library(ti
对于造成的困惑,我深表歉意,但最终,我发布的第一个示例(在页面底部)并没有帮助我弄清楚 tidyeval 如何与 mutate 一起工作,所以我添加了一个新示例。 我想创建一个接受三个参数的函数: 一
这个问题在这里已经有了答案: How to take in text/character argument without quotes (2 个答案) 关闭 7 个月前。 我写了一个函数。在我的函
library(tidyverse) input_name expr: ^filter(data, "birth_year" == 19) env: global 第 6 行 exp
我是一名优秀的程序员,十分优秀!