误解创造r函数

时间:2015-01-27 11:31:51

标签: database r function unique

我正在尝试使用正在运行的命令行创建一个函数。我正在为看起来像这个

的数据集创建一个标识符
Nom Var1  Var2
N1    v11   v12
N2     .     .
N2     .     .
N3    V32   V32

我的命令是:transform(df$Nom, id=match(df$Nom, unique(df$Nom)))并且工作得很好。 但是,如果我写一个像ht一样的函数;我收到错误:" unique仅适用于矢量"

 createid<-function(var){
   x<- transform(var, id=match(var, unique(var)))
   ids<-paste0("id_",x[,2])
   return(ids)
 }
df$id<-createid(df$Nom)

类似地,如果Y写下面的函数,我在d $ var:对象类型&#39; closure&#39;中得到错误 Error。不是子集表

 createid<-function(d,var){
    x<- transform(d$var, id=match(d$var, unique(d$var)))
    ids<-paste0("id_",x[,2])
    return(ids)
  }
 df$id<-createid(d,Nom)

我认为在R中编写函数的方式我不理解,尤其是在数据框内调用变量时。有人可以帮我弄这个吗? 谢谢

1 个答案:

答案 0 :(得分:2)

您可以在不使用transform的情况下执行此操作。正如@LyzandeR在评论中提到的,最好使用d[[var]]代替d$var

createid <- function(d, var){
            d$id <- match(d[[var]], unique(d[[var]]))
             d }
createid(df, 'Nom')
#   Nom Var1 Var2 id
#1  N1  v11  v12  1
#2  N2    .    .  2
#3  N2    .    .  2
#4  N3  V32  V32  3

或者,如果您真的想使用$,那么您可以使用eval(parse(,但不推荐使用此路线而不是那么简单。

   createid1 <- function(d, var){
                 m1 <- match.call()
                 e1 <- eval(parse(text=paste0(deparse(m1$d),'$',m1$var)))
                 d$id <- match(e1, unique(e1))
                 d}

   createid1(df, 'Nom')
   #  Nom Var1 Var2 id
   #1  N1  v11  v12  1
   #2  N2    .    .  2
   #3  N2    .    .  2
   #4  N3  V32  V32  3

或者代替eval(parse

  createid2 <- function(d, var){
    args <- as.list(match.call())
    e1 <- eval(args$var, d)
    d$id <- match(e1, unique(e1))
    d
   }

 createid2(df, Nom)
 #  Nom Var1 Var2 id
 #1  N1  v11  v12  1
 #2  N2    .    .  2
 #3  N2    .    .  2
 #4  N3  V32  V32  3