- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
是否有规范的 base-R 方法来确定函数参数是否是对象名称而不是文字/表达式?
虽然通常不鼓励使用 NSE,但偶尔会有人有一个好主意并想使用它。 data.frame
是我认为“方便”的最简单用例:如果您包含已保存的向量,它将使用对象名称作为列名称。 (事实上 ,许多类(class)似乎都将此作为制作框架的最佳/唯一方法。)
vec <- 1234:1235
data.frame(vec)
# vec
# 1 1234
# 2 1235
但是输入原始向量,它并没有那么好:
data.frame(1234:1235)
# X1234.1235
# 1 1234
# 2 1235
在 base R 中执行这种形式的 NSE 的常用方法是使用 deparse(substitute(x))
,它将返回对象名称("vec"
) 或作为文字传递的表达式 ("1234:1235"
)。
存在一些 is.*
函数(例如,is.object
、is.expression
),尽管它们用于不同的目的。我不想依赖 is.vector
或类似的特定于结构的函数,因为它不会泛化为更复杂的结构化参数(无需大量定制)。
我的想法是try(get(.))
对象,如果由于某种原因(通常是“未找到”)而失败,则参数很可能是表达式或文字。 (如果未找到 NSE 对象,这将不起作用:library(ggplot2)
,并且调用环境中不可能有名为 "ggplot2"
的对象。 )
例如,
func <- function(x, ...) {
xname <- deparse(substitute(x))
isobj <- !inherits(try(get(xname), silent = TRUE), "try-error")
if (isobj) "yes" else "no"
}
func(zz)
# [1] "yes"
func(c(zz))
# [1] "no"
(假设 func
与 isobj
一起做的不仅仅是返回一个字符串。)
用处理省略号的技术扩展该方法,我可以做到:
my_names <- function(...) {
dot_obj_expr <- sapply(eval(substitute(alist(...))), deparse)
nms <- names(dot_obj_expr)
if (is.null(nms)) nms <- rep("", length(dot_obj_expr))
hasgoodnames <- nzchar(nms) |
!sapply(dot_obj_expr, function(obj) inherits(try(get(obj), silent = TRUE), "try-error"))
# rational starting point
goodnames <- sprintf("V%i", seq_along(dot_obj_expr))
# replace those that were already named
goodnames[nzchar(nms)] <- nms[nzchar(nms)]
# replace those that were not named but appear to be an object-name
goodnames[!nzchar(nms) & hasgoodnames] <- dot_obj_expr[!nzchar(nms) & hasgoodnames]
goodnames
}
zz <- 1
my_names(zz, abc = 1:3, 1:3)
# [1] "zz" "abc" "V3"
### less clear when an arg is not found
rm(zz)
my_names(zz, abc = 1:3, 1:3)
# [1] "V1" "abc" "V3"
它提供了(也许)更合理的名称使用约定。
我还没有进行基准测试或分析来了解这是否会产生任何重大的“惩罚”。我相信 try(get(.))
相当高效,并且由于到目前为止的代码没有改变任何对象,所以我认为不需要内存复制。
(此问题由 advanced-R 告知,http://adv-r.had.co.nz/Computing-on-the-language.html.)
最佳答案
我不确定它是否有帮助,但您似乎只想检查参数是一个符号还是其他东西。你可以这样做
func <- function(x, ...) {
xobj <- substitute(x)
if (is.symbol(xobj)) "yes" else "no"
}
func(zz)
# [1] "yes"
func(c(zz))
# [1] "no"
这将为 zz
返回"is",无论变量 zz
是否实际存在,这可能是也可能不是您想要的。
关于r - 名称和表达式之间的规范 NSE 区分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66643561/
我正在编写函数来自动化分析大量人口统计数据的工作流程。我可以从 dplyr 函数的常规管道流中获得我需要的东西,但我需要将其抽象为 NSE 函数。我通过 ... 参数为一系列 gather 调用提供列
我正在尝试编写一个函数,该函数接收数据框的名称和一列以使用 dplyr 进行汇总,然后返回汇总的数据框。我已经尝试了一系列来自 lazyeval 包的 interp() 排列,但我花了太多时间试图让它
是否有规范的 base-R 方法来确定函数参数是否是对象名称而不是文字/表达式? 虽然通常不鼓励使用 NSE,但偶尔会有人有一个好主意并想使用它。 data.frame 是我认为“方便”的最简单用例:
我很难弄清楚如何使用 dplyr::left_join 和 NSE 连接两个表。问题是我无法为“by”提供正确的值。我想我现在已经找到了一个解决方案,但感觉我正在以一种更加复杂的方式来做。所以,如果你
我可以 telnet 到某个主机和端口没有问题并发出命令。但是,当我尝试将套接字连接(使用 nmap NSE 和 Lua)编写到相同的主机和端口时,它会失败并显示以下错误消息: |_sockettes
我想从带有动态过滤器的sql服务器中提取一些数据。我通过以下方式使用了出色的R包dplyr: #Create the filter filter_criteria = ~ column1 %in% s
我想用 dplyr用于动态 filter 的新 NSE 符号(版本 >= 0.6)在我的数据上。假设我有以下虚拟数据集: df = data_frame(x = 1:10, y = 10:1, z =
我正在使用 NSEPY API,我想列出包含在 nifty 50 指数中的股票。 我正在获取个股的历史数据,但没有获取 50 只股票(总共 50 只股票)。我想找回它。 import nsepy fr
考虑以下生成汇总表的交互式示例: library(dplyr) tg % group_by(supp, dose) %>% summarise(N = n(), mea
导入请求 x = requests.get(' https://www1.nseindia.com/live_market/dynaContent/live_watch/equities_stock_
我仍在努力思考非标准评估以及它在 dplyr 中的使用方式.当函数参数是变量名时,我无法理解为什么惰性求值很重要,因此原始上下文的环境似乎并不重要。 在下面的代码中,函数 select3()使用惰性求
经过大量的反复试验和咨询以前的答案,例如 How to detect if bare variable or string我想我自己已经完成了大部分我需要做的事情。但是我很想知道在我将“解决方案”投入
我正在编写一个函数包,用于制作人口统计数据表。我有一个函数(缩写如下),我需要在其中获取几列 (...),并在其中收集 一个数据框。诀窍是我想保持这些列的名称按顺序排列,因为我需要在收集后按该顺序放置
此 python 代码在本地计算机上运行,但未在 上运行 digital ocean 亚马逊AWS Google 协作 赫罗库 以及许多其他 VPS。它在不同时间显示不同的错误。 import r
我正在尝试创建一个函数,根据列的位置选择 DF 中的列。我总是需要第一列,然后是 DF 的子集。我需要选择的每个子集都有 1 个对象。 到目前为止,我已经尝试过以下方法: position % s
想法是在函数中修补对 ggplot 的调用。 例子: library(dplyr) library(ggplot2) library(lazyeval) df % select_(~A,nam
我在终端中运行了这个脚本: nmap -p 80 --script http-joomla-brute --script-args 'passdb=/Users/abc/Documents/passw
所以我已经多次找到各种不同的方法来实现这一点,但在过去一年左右的时间里,dplyr 处理非标准评估的方式发生了变化。基本上实现这一目标的一种方法如下: require("dplyr") test %
我如何利用魔术点 (...)/省略号根据任意列进行过滤? df = tibble::tibble(col1 = c('a', 'b', 'c'), col2 = c(1,3,4)) my_func =
在这段代码中,我试图通过 Python 代码获取 NSE 选项链数据。 工具 - Spyder4 python - 3.7 代码没有抛出任何错误,我不知道我做错了什么。 PRINT 1 将我的正确输出
我是一名优秀的程序员,十分优秀!