【问题标题】:Defining default R function parameters on processed arguments在处理的参数上定义默认的 R 函数参数
【发布时间】:2019-04-12 08:25:54
【问题描述】:

我正在编写一个需要默认参数才能工作的包函数,但其​​值必须取自函数的已处理(其他)参数。 截至目前,我正在这样做:

myfunc <- function(x, y, n=NULL){
  processed <- some_other_func(x,y)
  x <- processed$x
  y <- processed$y
  if(is.null(n)){
    n <- length(intersect(x,y))/3
  }
  # do stuff
}

但理想情况下,我希望使用默认表达式而不是 NULL,因为如果我的文档说默认值是 length(intersect(x,y))/3,这似乎不一致。

你知道我可以指定默认参数更易于理解的方法吗?

【问题讨论】:

  • 可能是 missing() 而不是 is.null()stackoverflow.com/questions/7964830/…
  • 如果这个默认值需要输入其他函数参数,我真的没有看到比你正在做的更好的方法了。
  • 请注意 n=NULL, imo 是一个合法的默认值,只需在文档中指定如果缺少它将被设置为 length(..)

标签: r function


【解决方案1】:

也许你可以像这样解决它?

default_function <- function(v1, v2)
{
  return((v1 + v2)/2)
}

dummy_function <- function(x, y, n = default_function)
{
  x = x
  y = y
  if(class(n) == "function") n = n(x,y) # if n is any kind of function do it

  print(paste(x, y, n))

}


dummy_function(1, 2)
dummy_function(1, 2, 100)

【讨论】:

  • 嗯...我不确定这是否可行,因为 default_function 需要 已处理 xy
  • 我不确定我的理解是否正确,但是存储在 n 中的默认函数在 if-case 中执行时应该能够接收处理后的 x 和 y 值?
  • 但老实说,我认为设置 n = NULL 并按照@RLave 的建议在文档中给出解释比这里建议的 n = 某种函数的方法更容易理解。
  • 是的,我想你是对的。人们只需要开始阅读文档:P
猜你喜欢
  • 2011-08-26
  • 2021-04-08
  • 2014-03-28
  • 2021-05-04
  • 1970-01-01
  • 1970-01-01
  • 2018-07-08
  • 1970-01-01
  • 2016-09-27
相关资源
最近更新 更多