创建一个由多个函数组成的新函数,即 compose(f, g)
相当于 function(...) f(g(...))
。
参数
- ...
-
按顺序应用的函数(默认从右到左)。公式以通常的方式转换为函数。
支持Dynamic dots。特别是,如果您的函数存储在列表中,您可以将其与
!!!
拼接。 - .dir
-
如果是
"backward"
(默认值),则按相反的顺序(从右到左)调用函数,这与数学中的惯例一样。如果是"forward"
,则从左到右调用它们。
副词
该函数称为副词,因为它修饰函数(动词)的效果。如果您想在包中包含创建副词的函数,请务必阅读faq-adverbs-export。
也可以看看
其他副词:auto_browse()
, insistently()
, negate()
, partial()
, possibly()
, quietly()
, safely()
, slowly()
例子
not_null <- compose(`!`, is.null)
not_null(4)
#> [1] TRUE
not_null(NULL)
#> [1] FALSE
add1 <- function(x) x + 1
compose(add1, add1)(8)
#> [1] 10
fn <- compose(\(x) paste(x, "foo"), \(x) paste(x, "bar"))
fn("input")
#> [1] "input bar foo"
# Lists of functions can be spliced with !!!
fns <- list(
function(x) paste(x, "foo"),
\(x) paste(x, "bar")
)
fn <- compose(!!!fns)
fn("input")
#> [1] "input bar foo"
相关用法
- R purrr chuck 获取嵌套数据结构深处的元素,如果不存在则失败
- R purrr accumulate 累积向量缩减的中间结果
- R purrr imap 将函数应用于向量的每个元素及其索引
- R purrr list_transpose 转置列表
- R purrr as_vector 将列表强制转换为向量
- R purrr map_if 有条件地将函数应用于向量的每个元素
- R purrr map2 映射两个输入
- R purrr array-coercion 强制数组列出
- R purrr auto_browse 包装一个函数,以便在出错时自动 browser()
- R purrr pluck 安全地获取或设置嵌套数据结构深处的元素
- R purrr insistently 将函数转换为等待,然后在错误后重试
- R purrr map_depth 在给定深度映射/修改元素
- R purrr list_simplify 将列表简化为原子或 S3 向量
- R purrr rerun 多次重新运行表达式
- R purrr quietly 包装一个函数来捕获副作用
- R purrr list_flatten 压平列表
- R purrr pmap 同时映射多个输入(“并行”)
- R purrr possibly 包装函数以返回值而不是错误
- R purrr head_while 查找全部满足谓词的头/尾。
- R purrr rbernoulli 从伯努利分布生成随机样本
- R purrr rate-helpers 创建延迟率设置
- R purrr keep_at 根据元素的名称/位置保留/丢弃元素
- R purrr keep 根据元素的值保留/丢弃元素
- R purrr transpose 转置列表。
- R purrr flatten 将列表的列表展平为简单的向量
注:本文由纯净天空筛选整理自Hadley Wickham等大神的英文原创作品 Compose multiple functions together to create a new function。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。