Answers:
这是一个单行代码,可删除除函数以外的所有对象:
rm(list = setdiff(ls(), lsf.str()))
它用于setdiff
查找全局环境(由返回ls()
)中没有模式function
(由返回lsf.str()
)的对象的子集
.
要了解我在说什么,请尝试.j <- 5; ls(); ls(all.names=TRUE)
发布的setdiff
答案很好。我只是以为我会发布我之前写的这个相关函数。它的用处取决于读者:-)。
lstype<-function(type='closure'){
inlist<-ls(.GlobalEnv)
if (type=='function') type <-'closure'
typelist<-sapply(sapply(inlist,get),typeof)
return(names(typelist[typelist==type]))
}
ls.str()
测试对象mode
而不是typeof
对象的代码进行了有趣的比较。(顺便提一下,如果我能从他们的文档中找出两者之间的区别,我会感到很惊讶)。
这是一个非常方便的功能,我在某处拾取并进行了一些调整。保留在目录中可能会很好。
list.objects <- function(env = .GlobalEnv)
{
if(!is.environment(env)){
env <- deparse(substitute(env))
stop(sprintf('"%s" must be an environment', env))
}
obj.type <- function(x) class(get(x, envir = env))
foo <- sapply(ls(envir = env), obj.type)
object.name <- names(foo)
names(foo) <- seq(length(foo))
dd <- data.frame(CLASS = foo, OBJECT = object.name,
stringsAsFactors = FALSE)
dd[order(dd$CLASS),]
}
> x <- 1:5
> d <- data.frame(x)
> list.objects()
# CLASS OBJECT
# 1 data.frame d
# 2 function list.objects
# 3 integer x
> list.objects(env = x)
# Error in list.objects(env = x) : "x" must be an environment
我写这是为了删除当前环境中函数以外的所有对象(使用的编程语言是IDE R-Studio中的R):
remove_list=c() # create a vector
for(i in 1:NROW(ls())){ # repeat over all objects in environment
if(class(get(ls()[i]))!="function"){ # if object is *not* a function
remove_list=c(remove_list,ls()[i]) # ..add to vector remove_list
}
}
rm(list=remove_list) # remove all objects named in remove_list
笔记-
rm(list =)中的参数“ list”必须是字符向量。
当前环境中位置i处的对象名称从ls()[i]返回,而对象本身从get(ls()[i])返回。因此,对象的类是从class(get(ls()[i]))返回的
rm(list=setdiff(ls(all.names=TRUE), lsf.str(all.names=TRUE)))