gpt4 book ai didi

r - rlang::fn_fmls() 可以嵌套吗?

转载 作者:行者123 更新时间:2023-12-04 08:48:33 25 4
gpt4 key购买 nike

文档表明这是可能的:

fn <- function(a = 1, b = 2) rlang::fn_fmls() 
fn()

$a
[1] 1

$b
[1] 2
我要 rlang::fn_fmls()在一个函数中,并为当前范围内的参数返回相同的结构。
预期行为:
x <- function(a, b){
rlang::fn_fmls(fn = rlang::current_fn())
}

x(a = 1, b = 2)

$a
[1] 1

$b
[1] 2
实际行为:
x <- function(a, b){
rlang::fn_fmls(fn = rlang::current_fn())
}

x(a = 1, b = 2)

$a


$b
我尝试过的另一种方法是:
x <- function(a, b){
tmp <- base::match.call() %>%
base::as.list()


tmp %>%
stringr::str_detect('x') %>%
purrr::discard(tmp, .)
}

x(a = 1, b = 2)

$a
[1] 1

$b
[1] 2
rlang 有没有办法得到我想要的结果?

最佳答案

您在找 rlang::call_args ?

x <- function(a, b) rlang::call_args(sys.call())

x(a = 1, b = 2)
#> $a
#> [1] 1
#>
#> $b
#> [1] 2
如果您正在寻找要“填充”的默认参数,那么您可以执行以下操作:
x <- function(a = 1, b = 2)
{
f <- rlang::fn_fmls()
mc <- as.list(match.call())[-1]
append(mc, f[!names(f) %in% names(mc)])[names(f)]
}
这会产生以下行为:
x()
#> $a
#> [1] 1
#>
#> $b
#> [1] 2

x(a = 5)
#> $a
#> [1] 5
#>
#> $b
#> [1] 2

x(b = 7)
#> $a
#> [1] 1
#>
#> $b
#> [1] 7

x(a = 5, b = 7)
#> $a
#> [1] 5
#>
#> $b
#> [1] 7
创建于 2020-10-03 由 reprex package (v0.3.0)

关于r - rlang::fn_fmls() 可以嵌套吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64188387/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com