Dav*_*sak 6 printing console r
我在 R 中创建了一个类,并尝试为该类创建一个打印函数。我希望打印函数打印传递给打印函数的对象的名称。使用标准deparse(substitute())我可以获取变量的名称,这在我print()直接调用函数时有效。但当我只是从 R Studio 运行变量时它不起作用。它显然正在调用我的打印函数。但有一些间接导致它丢失变量名称。这是一个例子:
# Define class 'myobj'
myobj <- function(val) {
obj <- structure(list(), class = c("myobj", "list"))
obj$value = val
return(obj)
}
# Write custom print function for 'myobj' class
#' @export
print.myobj <- function(x, ...) {
nm <- deparse1(substitute(x, env = environment()))
cat(paste0("My object name: ", nm, "\n"))
cat(paste0("My object value: ", x$value, "\n"))
invisible(x)
}
myInstance <- myobj(123)
# Prints name and value.
print(myInstance)
#> My object name: myInstance
#> My object value: 123
# Prints value, but name is local variable 'x'.
myInstance
#> My object name: x
#> My object value: 123
Run Code Online (Sandbox Code Playgroud)
似乎当您直接运行该变量时,它会嵌套在另一个框架或环境中,从而deparse(substitute())无法正常工作。
我怎样才能让我的打印函数可靠地打印变量的名称,无论它是如何调用的?
自动打印文档说它是由 处理的print.c。
这个函数看起来像这样。
static void PrintObjectS3(SEXP s, R_PrintData *data)
{
/*
Bind value to a variable in a local environment, similar to
a local({ x <- <value>; print(x) }) call. This avoids
problems in previous approaches with value duplication and
evaluating the value, which might be a call object.
*/
SEXP xsym = install("x");
SEXP mask = PROTECT(NewEnvironment(R_NilValue, R_NilValue, data->env));
defineVar(xsym, s, mask);
/* Forward user-supplied arguments to print() */
SEXP fun = PROTECT(findFun(install("print"), R_BaseNamespace));
SEXP args = PROTECT(cons(xsym, data->callArgs));
SEXP call = PROTECT(lcons(fun, args));
eval(call, mask);
defineVar(xsym, R_NilValue, mask); /* To eliminate reference to s */
UNPROTECT(4); /* mask, fun, args, call */
}
Run Code Online (Sandbox Code Playgroud)
请注意,它说
类似于
local({ x <- <value>; print(x) })
所以自动打印并不直接调用print(myInstance). 它用符号做事x,所以我认为以您想要的方式获取变量名称是不可能的。
通过查看 就可以看出差异traceback。
print.myobj <- function(x, ...) {
stop()
}
print(myInstance)
#> (Traceback)
#> 3. stop()
#> 2. print.myobj(myInstance)
#> 1. print(myInstance)
myInstance
#> (Traceback)
#> 3. stop()
#> 2. print.myobj(x)
#> 1. (function (x, ...)
#> UseMethod("print"))(x)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
935 次 |
| 最近记录: |