R语言批量读入数据文件到一个数据集

原文地址:http://blog.163.com/ruby_geh/blog/static/260528078201611238410176/

在流水化办公中,通常有格式统一的表格文件产生,但是到最后要将这一堆表格文件整合为大表却很揪心,累断手,如何用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)


  • 3
    点赞
  • 53
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值