python合并两个excel文件_Python将多个excel文件合并为一个文件

利用Python,将多个excel文件合并为一个文件

思路

利用python xlrd包读取excle文件,然后将文件内容存入一个列表中,再利用xlsxwriter将内容写入到一个新的excel文件中。

完整代码

# -*- coding: utf-8 -*-

#将多个Excel文件合并成一个

import xlrd

import 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 x

if __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:

3e0b66ab968ea4ae8b0c9d9fa5252d34.jpg

64899efd4d93f7cd5718802bfa900d07.jpg

源文件excel2:

eb389f68f42b387e7d5298e2aaa177c3.jpg

1442a6d390f7529cdb56f8c93839062a.jpg

31826412862ae155cbbd69f9739fda18.jpg

运行结果:

fbc9a0219bcfad3726327df0c84dd758.jpg

合并后的excel3:

af97a1ad92a1bf6d54f19fd1c634ad68.jpg

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

表情包
插入表情
评论将由博主筛选后显示,对所有人可见 | 还能输入1000个字符
©️2021 CSDN 皮肤主题: 1024 设计师:白松林 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值