r语言 - 定义具有 2 个以上参数的运算符



我想知道有没有办法向运算符提供超过 2 个参数,或者除了使用函数格式我别无选择!例如,我可以定义需要 2 个以上 Arg 的合并运算符。

这只是一个例子,我对合并功能不感兴趣:

1.我做了一个运算符来合并两个数据框及其公共列名A%>>%B

`%>>%`<- function(a,b){
      by.tmp = intersect(names(a),names(b))
      base::merge(a,b,by = by.tmp)
}

2.现在我正在寻找一种方法来定义应该从 data.frame A 到 data.frame B 匹配哪一列,例如:

A %column_name_a>>column_name_b% B
# or feeding 2 arg from each side to operator like follow 
# which inside parenthesis return another operator
A (column_name_a %>>% column_name_b) B
# or more advanced
A:column_name_list_a%>>%column_name_list_b:B

我知道如何使用函数来做到这一点,我只想知道有没有办法定义更复杂的运算符来抽象我的代码。

更新:我设法纠正了一个参数数量未知的运算符(这有点级联,但它有效)。方法是:

`%>%` <- function(a,b){
  ifvalid <- function(a, frame = parent.frame()){
    res = try(eval(a,frame),silent = T)
    flag = inherits(res, "try-error") | (length(res)==0)
    ifelse ((!flag) | (length(a)==1) , return(res),  return(
      lapply(a, ifvalid,frame=frame)
      )
    )
  }

  left_arg = substitute(a)
  right_arg= substitute(b)
  res = list(
    left = ifvalid(left_arg),
    right = ifvalid(right_arg)
  )
  return(res)
}

示例运行为:

"X":1:NULL %>% date():`*`
# $left
# $left[[1]]
# .Primitive(":")
# 
# $left[[2]]
# $left[[2]][[1]]
# .Primitive(":")
# 
# $left[[2]][[2]]
# [1] "X"
# 
# $left[[2]][[3]]
# [1] 1
# 
# 
# $left[[3]]
# list()
# 
# 
# $right
# $right[[1]]
# .Primitive(":")
# 
# $right[[2]]
# [1] "Wed Feb 03 16:04:17 2016"
# 
# $right[[3]]
# function (e1, e2)  .Primitive("*")

在注释中说明上述方法:

 `%>>%`<- function(a,b){
             base::merge(a,b[[1]],by = b[[2]])
 }
 authors %>>% list(books, "name")
 #-------
      name nationality deceased                         title other.author
1   McNeil   Australia       no     Interactive Data Analysis         <NA>
2   Ripley          UK       no            Spatial Statistics         <NA>
3   Ripley          UK       no         Stochastic Simulation         <NA>
4  Tierney          US       no                     LISP-STAT         <NA>
5    Tukey          US      yes     Exploratory Data Analysis         <NA>
6 Venables   Australia       no Modern Applied Statistics ...       Ripley

使用的日期是?merge帮助页面上代码的略微简化版本:

authors <- data.frame(
    name = I(c("Tukey", "Venables", "Tierney", "Ripley", "McNeil")),
    nationality = c("US", "Australia", "US", "UK", "Australia"),
    deceased = c("yes", rep("no", 4)))
books <- data.frame(
    name = I(c("Tukey", "Venables", "Tierney",
             "Ripley", "Ripley", "McNeil", "R Core")),
    title = c("Exploratory Data Analysis",
              "Modern Applied Statistics ...",
              "LISP-STAT",
              "Spatial Statistics", "Stochastic Simulation",
              "Interactive Data Analysis",
              "An Introduction to R"),
    other.author = c(NA, "Ripley", NA, NA, NA, NA,
                     "Venables & Smith"))

相关内容

  • 没有找到相关文章

最新更新