使用Python將多個excel合并為一個文件的技巧
利用python xlrd包讀取excle文件,然后將文件內(nèi)容存入一個列表中,再利用xlsxwriter將內(nèi)容寫入到一個新的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表的行數(shù)
def getnrows(fh,sheet):
table=fh.sheets()[sheet]
return table.nrows
#讀取文件內(nèi)容并返回行內(nèi)容
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表的個數(shù)
def getshnum(fh):
sh=getsheet(fh)
for sheet in sh:
x+=1
return x
if __name__=='__main__':
#定義要合并的excel文件列表
allxls=['F:/test/excel1.xlsx','F:/test/excel2.xlsx']
#存儲所有讀取的結(jié)果
datavalue=[]
for fl in allxls:
fh=open_xls(fl)
x=getshnum(fh)
for shnum in range(x):
print("正在讀取文件:"+str(fl)+"的第"+str(shnum)+"個sheet表的內(nèi)容...")
rvalue=getFilect(fl,shnum)
#定義最終合并后生成的新文件
endfile='F:/test/excel3.xlsx'
wb1=xlsxwriter.Workbook(endfile)
#創(chuàng)建一個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("文件合并完成")
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62
源文件excel1:
源文件excel2:
運行結(jié)果:
合并后的excel3: