Python將多個(gè)excel表格合并為一個(gè)表格
生活中經(jīng)常會(huì)碰到多個(gè)excel表格匯總成一個(gè)表格的情況,比如你發(fā)放了一份表格讓班級所有同學(xué)填寫,而你負(fù)責(zé)將大家的結(jié)果合并成一個(gè)。諸如此類的問題有很多。除了人工將所有表格的內(nèi)容一個(gè)一個(gè)復(fù)制到匯總表格里,那么如何用Python自動(dòng)實(shí)現(xiàn)這些工作呢~
我不知道有沒有其他更方便的合并方法,先用Python實(shí)現(xiàn)這個(gè)功能,自己用就很方便了。
比如,在文件夾下有如下7個(gè)表格(想象一下有100個(gè)或更多的表格需要合并)
作為樣例,每個(gè)表格的內(nèi)容均為
運(yùn)行程序,將7個(gè)表格合并成了test.xls
打開test.xls,發(fā)現(xiàn)成功合并了多個(gè)表格的數(shù)據(jù)到一個(gè)表格里
代碼運(yùn)行之前,需要安裝Numpy,xlrd,xlwt三個(gè)擴(kuò)展包。話不多說,代碼如下
#下面這些變量需要您根據(jù)自己的具體情況選擇 biaotou=['學(xué)號','學(xué)生姓名','第一志愿','第二志愿','第三志愿','第四志愿','第五志愿','聯(lián)系電話','性別','備注'] #在哪里搜索多個(gè)表格 filelocation="C:\\Users\\ann\Documents\\Python Scripts\\" #當(dāng)前文件夾下搜索的文件名后綴 fileform="xls" #將合并后的表格存放到的位置 filedestination="C:\\Users\\ann\Documents\\Python Scripts\\" #合并后的表格命名為file file="test" #首先查找默認(rèn)文件夾下有多少文檔需要整合 import glob from numpy import * filearray=[] for filename in glob.glob(filelocation+"*."+fileform): filearray.append(filename) #以上是從pythonscripts文件夾下讀取所有excel表格,并將所有的名字存儲到列表filearray print("在默認(rèn)文件夾下有%d個(gè)文檔哦"%len(filearray)) ge=len(filearray) matrix = [None]*ge #實(shí)現(xiàn)讀寫數(shù)據(jù) #下面是將所有文件讀數(shù)據(jù)到三維列表cell[][][]中(不包含表頭) import xlrd for i in range(ge): fname=filearray[i] bk=xlrd.open_workbook(fname) try: sh=bk.sheet_by_name("Sheet1") except: print ("在文件%s中沒有找到sheet1,讀取文件數(shù)據(jù)失敗,要不你換換表格的名字?" %fname) nrows=sh.nrows matrix[i] = [0]*(nrows-1) ncols=sh.ncols for m in range(nrows-1): matrix[i][m] = ["0"]*ncols for j in range(1,nrows): for k in range(0,ncols): matrix[i][j-1][k]=sh.cell(j,k).value #下面是寫數(shù)據(jù)到新的表格test.xls中哦 import xlwt filename=xlwt.Workbook() sheet=filename.add_sheet("hel") #下面是把表頭寫上 for i in range(0,len(biaotou)): sheet.write(0,i,biaotou[i]) #求和前面的文件一共寫了多少行 zh=1 for i in range(ge): for j in range(len(matrix[i])): for k in range(len(matrix[i][j])): sheet.write(zh,k,matrix[i][j][k]) zh=zh+1 print("我已經(jīng)將%d個(gè)文件合并成1個(gè)文件,并命名為%s.xls.快打開看看正確不?"%(ge,file)) filename.save(filedestination+file+".xls")
我的運(yùn)行環(huán)境是windows7 ,64位。Python版本是3.5.1,32位。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python3.x實(shí)現(xiàn)base64加密和解密
這篇文章主要為大家詳細(xì)介紹了python3.x實(shí)現(xiàn)base64加密和解密,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-03-03