将函数调用向量折叠成一行,用 & 分隔每个调用,使用替代和减少?

如何解决将函数调用向量折叠成一行,用 & 分隔每个调用,使用替代和减少?

我正在尝试构造函数调用 str_detect(words,"a") & str_detect(words,"e") & str_detect(words,"i") & str_detect(words,"o") & str_detect(words,"u") 而不进行所有那些痛苦的输入。我知道这不是解决问题的好方法,但在 doing a poor job of solving it a better way 之后,我决定尝试这样做,看看我是否可以从中学到任何东西。

我的尝试如下:

library(stringr)
funList <- sapply(c("a","e","i","o","u"),function(y) substitute(str_detect(words,x),list(x=y)))
Reduce(function(a,b) paste(a,"&",b),funList)

这几乎奏效了。 funList 几乎是我们所期望的:

> funList
$a
str_detect(words,"a")

$e
str_detect(words,"e")

$i
str_detect(words,"i")

$o
str_detect(words,"o")

$u
str_detect(words,"u")

但最后一行给出了一些非常出乎意料的输出,大概是由于 R 构造函数调用的方式:

> Reduce(function(a,funList)
[1] "str_detect & str_detect & str_detect & str_detect & str_detect"
[2] "words & words & words & words & words"                         
[3] "a & e & i & o & u"

这可以修复以提供预期的函数调用吗?我尝试了一些技巧,比如抛出 quote 函数,但我没有取得任何成果。

解决方法

funList 您可以通过 -

实现预期输出
paste(funList,collapse = ' & ')

#[1] "str_detect(words,\"a\") & str_detect(words,\"e\") & str_detect(words,\"i\") & str_detect(words,\"o\") & str_detect(words,\"u\")"

但是,您不需要 sapply 来构造 funList -

paste0(sprintf('str_detect(words,"%s")',c("a","e","i","o","u")),\"u\")"
,

这是一个非常糟糕的通用方法。您可能也不需要这样做。

但是,如果您继续在语言上进行计算并利用运算符实际上被解析为函数,那将非常容易:

funList <- lapply(c("a","u"),function(y) substitute(str_detect(words,x),list(x=y)))
Reduce(function(a,b) substitute(`&`(a,b),list(a = a,b = b)),funList)
#str_detect(words,"a") & str_detect(words,"e") & str_detect(words,#    "i") & str_detect(words,"o") & str_detect(words,"u")
,

我们可以使用str_c

library(stringr)
str_c(funList,collapse = ' & ')

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?