首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在r中函数定义中如何正确使用dplyr动词?

在r中函数定义中如何正确使用dplyr动词?
EN

Stack Overflow用户
提问于 2017-01-23 15:51:18
回答 1查看 708关注 0票数 3

我想在我的函数中使用来自filtersummarisedplyr。如果没有函数,它的工作方式如下所示:

代码语言:javascript
运行
复制
library(dplyr)
> Orange %>% 
+     filter(Tree==1) %>% 
+     summarise(age_max = max(age))
  age_max
1    1582  

我想在函数中执行同样的操作,但是下面的操作失败了:

代码语言:javascript
运行
复制
## Function definition:

df.maker <- function(df, plant, Age){

  require(dplyr)

  dfo <- df %>% 
    filter(plant==1) %>% 
    summarise(age_max = max(Age))

  return(dfo)
}

## Use:
> df.maker(Orange, Tree, age)

 Rerun with Debug
 Error in as.lazy_dots(list(...)) : object 'Tree' not found

我知道以前也有人问过类似的问题。我还浏览了一些相关链接,如page1page2。但我不能完全理解NSE和SE的概念。我试过以下几点:

代码语言:javascript
运行
复制
df.maker <- function(df, plant, Age){

  require(dplyr)

  dfo <- df %>% 
    filter_(plant==1) %>% 
    summarise_(age_max = ~max(Age))

  return(dfo)
} 

但也有同样的错误。请帮我理解一下发生了什么事。如何才能正确地创建我的函数呢?谢谢!

编辑:

我还尝试了以下几点:

代码语言:javascript
运行
复制
df.maker <- function(df, plant, Age){

  require(dplyr)

  dfo <- df %>% 
    #filter_(plant==1) %>% 
    summarise_(age_max = lazyeval::interp(~max(x),
                                          x = as.name(Age)))

  return(dfo)
}  

> df.maker(Orange, Tree, age)
 Error in as.name(Age) : object 'age' not found 
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-01-23 16:24:25

提供字符参数并使用as.name

代码语言:javascript
运行
复制
df.maker1 <- function(d, plant, Age){
  require(dplyr)
  dfo <- d %>% 
    filter_(lazyeval::interp(~x == 1, x = as.name(plant))) %>% 
    summarise_(age_max = lazyeval::interp(~max(x), x = as.name(Age)))
  return(dfo)
}  
df.maker1(Orange, 'Tree', 'age')

age_max 1 1582

或者用substitute捕获参数

代码语言:javascript
运行
复制
df.maker2 <- function(d, plant, Age){
  require(dplyr)
  plant <- substitute(plant)
  Age <- substitute(Age)

  dfo <- d %>% 
    filter_(lazyeval::interp(~x == 1, x = plant)) %>% 
    summarise_(age_max = lazyeval::interp(~max(x), x = Age))
  return(dfo)
}  
df.maker2(Orange, Tree, age)

age_max 1 1582

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41810320

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档