打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
R语言读取文件夹下多个文件并进行合并数据生成总数据文件

转自:http://blog.csdn.net/qq_34941023/article/details/51550085

 

在流水化办公中,通常有格式统一的表格文件产生,但是到最后要将这一堆表格文件整合为大表却很揪心,累断手,如何用R语言进行一次性导入整合呢?

假设我们将D:/input文件夹作为需要导入的表格的存放点,文件夹内所有文件均为此次需要导入数据,那么可以用以下程序进行操作

 setwd("D:/")                                                                    #设定工作目录为D盘
 a = list.files("input")                                                       #list.files命令将input文件夹下所有文件名输入a
 dir = paste("./input/",a,sep="")                                      #用paste命令构建路径变量dir
n = length(dir)                                                                 #读取dir长度,也就是文件夹下的文件个数
 merge.data = read.csv(file = dir[1],header=T,sep=",")   #读入第一个文件内容(可以不用先读一个,但是为了简单,省去定义data.frame的时间,我选择先读入一个文件。
 for (i in 2:n){
   new.data = read.csv(file = dir[i], header=T, sep=",")
   merge.data = rbind(merge.data,new.data)
 }

#循环从第二个文件开始读入所有文件,并组合到merge.data变量中
write.csv(merge.data,file = "./input/merge.csv",row.names=F)  #输出组合后的文件merge.csv到input文件夹

 

PS.若为TXT文件

 #==============批量读入TXT文件======================

a = list.files("input")

dir = paste("./input/",a,sep="")            

n = length(dir)     

merge.data = read.table(file = dir[1],header=TRUE,dec = ".")

for (i in 2:n){

  new.data = read.table(file = dir[i], header=TRUE, dec = ".")

  merge.data = rbind(merge.data,new.data)

}

write.table(merge.data,file = "./input/merge.txt",row.names=F)  

#===========================================================

 

 

另外,如果懒得转换为csv,在所有excel都是只有一个sheet的时候,可以用下面的命令作为读取

首先在最开头需要安装和调用package:

install.packages("XLConnect")
 library("XLConnect")

 

 然后在正文中将 merge.data = read.csv(file = dir[1],header=T,sep=",")替换为 

merge.data = readWorksheetFromFile(file = dir[i], sheet=1, header=TRUE)

 

将new.data = read.csv(file = dir[i], header=T, sep=",")替换为

 new.data = readWorksheetFromFile(file = dir[i], sheet=1, header=TRUE)

 

写入新文件除需要复杂一点,基于下面的程序,大家可以尝试改写一下:

# 读取或创建一个XLSX文件,此步相当于建立一个连接
xls <- loadWorkbook('test.xlsx',create=TRUE)
# 创建工作表
createSheet(xls,name='namesheet')
# 写入数据
writeWorksheet(xls,iris,'nameshee',
               startRow=1,startCol=1, # 数据出现的左上角位置
               header=TRUE)
# 存入硬盘,直到此步方才有文档生成
saveWorkbook(xls)

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
R|批量循环处理同一格式文件-csv,txt,excel
将所有的csv文件,放到一个csv文件中,并按列排列
php文件下载代码
VBA——汇总一个文件夹下面的所有文件到EXCEL中
python 使用win32com实现对word文档批量替换页眉页脚
自动化办公:python文件分类器,一键完成杂乱无章的文件整理
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服