我有一系列十个数据框,包含两列x和y。我想为包含数据框名称的每个数据框添加一个新列。我遇到的问题是如何使用变量引用数据框,以便我可以迭代地执行此任务。除了通过变量名称引用它之外,我还尝试了get(),如下所示:
for(i in 1:10){
name <- paste(substr(fileList, 3, 7),i, sep = "")
assign(newName, as.data.frame(get(name)))
get(newName)$Species = c(paste(substr(fileList, 3, 7),i, sep = ""))
}
但是,当我这样做时,我收到以下错误:
Error in get(newName)$Species = c(paste(substr(fileList[a], 3, 7), i, :
could not find function "get<-"
是否有另一种方法来表示列分配命令,以便我可以解决此错误,或者解决方案是否更复杂?
答案 0 :(得分:5)
如果将所有数据框放入命名列表,则有三种不同的选项:
df_list <- list(a = data.frame(x = 1:5),
b = data.frame(x = 1:5))
#Option 1
for (i in seq_along(df_list)){
df_list[[i]][,'Species'] <- names(df_list)[i]
}
#Option 2
tmp <- do.call(rbind,df_list)
tmp$Species <- rep(names(df_list),times = sapply(df_list,nrow))
split(tmp,tmp$Species)
#Option 3
mapply(function(x,y) {x$Species <- y; x},df_list,names(df_list),SIMPLIFY = FALSE)