我希望卸载一个包而不必重新启动R(主要是因为在尝试不同的、冲突的包时重新启动R会令人沮丧,但可以想象,这可以在程序中使用一个函数,然后使用另一个函数——尽管名称空间引用可能是更好的使用方法)。
?库没有显示任何卸载包的选项。
有一个建议detach可以卸载包,但以下两个都失败:
detach(vegan)
分离错误(纯素):无效的名称参数
detach("vegan")
分离错误("vegan"):无效的名称参数
那我怎么卸货呢?
我希望卸载一个包而不必重新启动R(主要是因为在尝试不同的、冲突的包时重新启动R会令人沮丧,但可以想象,这可以在程序中使用一个函数,然后使用另一个函数——尽管名称空间引用可能是更好的使用方法)。
?库没有显示任何卸载包的选项。
有一个建议detach可以卸载包,但以下两个都失败:
detach(vegan)
分离错误(纯素):无效的名称参数
detach("vegan")
分离错误("vegan"):无效的名称参数
那我怎么卸货呢?
当前回答
你也可以使用unloadNamespace命令,如下所示:
unloadNamespace("sqldf")
该函数在卸载名称空间之前将其分离。
其他回答
我想补充一个替代方案。这个解决方案并没有直接回答你卸载包的问题,但是,恕我直言,提供了一个更干净的替代方案来实现你想要的目标,这是我所理解的,广泛关注于避免名称冲突和尝试不同的功能,如前所述:
主要是因为当我尝试不同的、冲突的包时重新启动R是令人沮丧的,但可以想象,这可以在程序中使用一个函数,然后使用另一个函数——尽管命名空间引用可能是更好的使用方法
解决方案
withr包提供的with_package函数提供了以下功能:
将包附加到搜索路径,执行代码,然后从搜索路径中删除包。但是,包名称空间不会被卸载。
例子
library(withr)
with_package("ggplot2", {
ggplot(mtcars) + geom_point(aes(wt, hp))
})
# Calling geom_point outside withr context
exists("geom_point")
# [1] FALSE
示例中使用的Geom_point不能从全局名称空间访问。我认为这可能是一种比装卸包裹更干净的处理冲突的方式。
试试这个(详见detach):
detach("package:vegan", unload=TRUE)
可以一次加载一个包的多个版本(例如,如果您在不同的库中有一个开发版本和一个稳定版本)。要确保所有副本都被分离,请使用此函数。
detach_package <- function(pkg, character.only = FALSE)
{
if(!character.only)
{
pkg <- deparse(substitute(pkg))
}
search_item <- paste("package", pkg, sep = ":")
while(search_item %in% search())
{
detach(search_item, unload = TRUE, character.only = TRUE)
}
}
例如,用法是
detach_package(vegan)
or
detach_package("vegan", TRUE)
detach(package:PackageName)有效,不需要使用引号。
我尝试了kohske写的答案,我又得到了错误,所以我做了一些搜索,发现这对我有用(R 3.0.2):
require(splines) # package
detach(package:splines)
或者还
library(splines)
pkg <- "package:splines"
detach(pkg, character.only = TRUE)
你也可以使用unloadNamespace命令,如下所示:
unloadNamespace("sqldf")
该函数在卸载名称空间之前将其分离。