1. 程式人生 > >利用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:

這裡寫圖片描述這裡寫圖片描述

原始檔excel2:
這裡寫圖片描述這裡寫圖片描述
這裡寫圖片描述

執行結果:

這裡寫圖片描述

合併後的excel3:
這裡寫圖片描述