作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
文档表明这是可能的:
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/
文档表明这是可能的: fn % base::as.list() tmp %>% stringr::str_detect('x') %>%
我是一名优秀的程序员,十分优秀!