我不知道执行此操作的内置方法,但您可以轻松编写自己的函数来执行这些操作。例如,这只是在没有任何检查以确保对象存在或是否已经存在名为您要重命名的对象的情况下进行。
mv <- function(x, y){
x_name <- deparse(substitute(x))
y_name <- deparse(substitute(y))
assign(y_name, x, pos = 1)
rm(list = x_name, pos = 1)
invisible()
}
一些示例使用
> x <- 3
> x
[1] 3
> y
Error: object 'y' not found
> mv(x, y)
> x
Error: object 'x' not found
> y
[1] 3
编辑:对于那些没有遵循评论中的链接的人,这里是 Rolf Turner 编写的版本,它进行了一些检查以确保我们要移动的对象确实存在,并询问我们是否要覆盖现有对象,如果新名称中已经有一个对象。
mv <- function (a, b) {
anm <- deparse(substitute(a))
bnm <- deparse(substitute(b))
if (!exists(anm,where=1,inherits=FALSE))
stop(paste(anm, "does not exist.\n"))
if (exists(bnm,where=1,inherits=FALSE)) {
ans <- readline(paste("Overwrite ", bnm, "? (y/n) ", sep = ""))
if (ans != "y")
return(invisible())
}
assign(bnm, a, pos = 1)
rm(list = anm, pos = 1)
invisible()
}