时间:2021-05-22
利用Python,将多个excel文件合并为一个文件
思路
利用python xlrd包读取excle文件,然后将文件内容存入一个列表中,再利用xlsxwriter将内容写入到一个新的excel文件中。
完整代码
# -*- coding: utf-8 -*-#将多个Excel文件合并成一个import xlrdimport xlsxwriter#打开一个excel文件def open_xls(file): fh=xlrd.open_workbook(file) return fh#获取excel中所有的sheet表def getsheet(fh): return fh.sheets()#获取sheet表的行数def getnrows(fh,sheet): table=fh.sheets()[sheet] return table.nrows#读取文件内容并返回行内容def getFilect(file,shnum): fh=open_xls(file) table=fh.sheets()[shnum] num=table.nrows for row in range(num): rdata=table.row_values(row) datavalue.append(rdata) return datavalue#获取sheet表的个数def getshnum(fh): x=0 sh=getsheet(fh) for sheet in sh: x+=1 return xif __name__=='__main__': #定义要合并的excel文件列表 allxls=['F:/test/excel1.xlsx','F:/test/excel2.xlsx'] #存储所有读取的结果 datavalue=[] for fl in allxls: fh=open_xls(fl) x=getshnum(fh) for shnum in range(x): print("正在读取文件:"+str(fl)+"的第"+str(shnum)+"个sheet表的内容...") rvalue=getFilect(fl,shnum) #定义最终合并后生成的新文件 endfile='F:/test/excel3.xlsx' wb1=xlsxwriter.Workbook(endfile) #创建一个sheet工作对象 ws=wb1.add_worksheet() for a in range(len(rvalue)): for b in range(len(rvalue[a])): c=rvalue[a][b] ws.write(a,b,c) wb1.close() print("文件合并完成")源文件excel1:
源文件excel2:
运行结果:
合并后的excel3:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
当前目录下多个文件合并为一个文件1、将多个文件合并为一个文件没有添加换行符find./-name"iptv_authenticate_201801*"|xarg
应用场景:使用pandas把多个相同结构的Excel文件合并为一个。原始数据:相关代码:importosimportpandasaspd#将文件读取出来放一个列
tar是Unix和类Unix系统上文件打包工具,可以将多个文件合并为一个文件,打包后的文件名亦为“tar”。tar代表未被压缩的tar文
本文实例讲述了Python将多个映射合并为单个映射的方法。分享给大家供大家参考,具体如下:问题:在逻辑上将多个字典或映射合并为一个单独的映射结构,以此执行某些特
把合并的pdf分开方法: 1、点击开始界面上的“将文件合并为PDF”。 2、弹出合并界面,点击添加文件(如果文件很多,可以把文件集中在一个新建文件夹内,然后