利用Python將多個excel檔案合併為一個檔案
阿新 • • 發佈:2019-02-12
利用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:
原始檔excel2:
執行結果:
合併後的excel3: