6

我有很多 .RData 文件,其中包含我在之前的分析中保存的一个数据框,并且该数据框对于加载的每个文件都具有相同的名称。因此,例如使用 load(file1.RData) 我得到一个名为“df”的数据框,然后使用 load(file2.RData) 我得到一个同名的数据框“df”。我想知道是否有可能将所有这些 .RData 文件合并到一个大 .RData 文件中,因为我需要一次加载它们,每个 df 的名称等于文件名,这样我就可以使用不同的数据帧。

我可以使用下面的代码来做到这一点,但它非常复杂,必须有更简单的方法来做到这一点……谢谢你的建议。

假设我有 3 个 .RData 文件,并希望将所有文件保存在一个名为“main.RData”的文件中,并使用它们的特定名称(现在它们都以“df”的形式出现):

all.files = c("/Users/fra/file1.RData", "/Users/fra/file2.RData", "/Users/fra/file3.RData")
assign(gsub("/Users/fra/", "", all.files[1]), local(get(load(all.files[1]))))
rm(list= ls()[!(ls() %in% (ls(pattern = "file")))])
save.image(file="main.RData")


all.files = all.files = c("/Users/fra/file1.RData", "/Users/fra/file2.RData", "/Users/fra/file3.RData")

for (f in all.files[-1]) {
  assign(gsub("/Users/fra/", "", f), local(get(load(f))))
  rm(list= ls()[!(ls() %in% (ls(pattern = "file")))])
  save.image(file="main.RData")
}
4

2 回答 2

5

这是一个包含多个现有帖子的选项

all.files = c("file1.RData", "file2.RData", "file3.RData")

将多个数据帧读入一个命名列表(如何将对象加载到我从 R 数据文件中指定的变量名中?

mylist<- lapply(all.files, function(x) {
  load(file = x)
  get(ls()[ls()!= "filename"])
})

names(mylist) <- all.files #Note, the names here don't have to match the filenames

您可以保存列表,或在保存之前将数据框传输到全局环境中(取消列出数据框列表

list2env(mylist ,.GlobalEnv)

或者,如果数据框相同并且您想创建一个大数据框,您可以折叠列表并添加一个带有贡献文件名称的变量(列表中的数据框;添加一个名称为数据框的新变量)。

all <- do.call("rbind", mylist)
all$id <- rep(all.files, sapply(mylist, nrow))
于 2016-01-10T23:21:16.390 回答
4

我认为我看到的最好的答案是下面的代码,我从一个我现在无法追踪的 SO 答案中复制了它。向原作者道歉。

resave <- function(..., list = character(), file) {
   previous  <- load(file)
   var.names <- c(list, as.character(substitute(list(...)))[-1L])
   for (var in var.names) assign(var, get(var, envir = parent.frame()))
   save(list = unique(c(previous, var.names)), file = file)
}
#I took advantage of the fact the load function 
#returns the name of the loaded variables, so 
#I could use the function's environment instead of creating one.
#And when using get, I was careful to only look in the 
#environment from which the function is called, i.e. parent.frame()
于 2013-02-07T18:00:33.140 回答