Python如何對多個sheet表進行整合?

flynike發表於2021-09-11

Python如何對多個sheet表進行整合?

說明

1、xlwt模組是非追加寫入.xls模組,所以要一次性寫入for迴圈和列表,這樣就沒有追加和非追加的說法。

2、將Excel表合併,將每一個Excel表作為行,即行合併,換個想法,將Excel表中的標籤作為列,可以進行列合併,即將不同檔案中相同標籤組成的不同標籤合併,可以先將不同檔案中相同的標籤合併,不同檔案中相同的標籤組成一個列表,然後將前面組成的不同標籤合併,就可以得到所有Excel檔案的內容。

例項

#匯入xlrd和xlwt模組
#xlrd模組是讀取.xls的Excel檔案的模組,xlwt模組是以非追加的方式寫.xls的Excel檔案的模組
import xlrd,xlwt
#匯入要讀的檔案的路徑
a=["C:/Users/Desktop/m1.xls","C:/Users/Desktop/m2.xls"]
#定義要寫的檔案的路徑
b="C:/Users/Desktop/m3.xls"
#定義函式,判斷開啟檔案是否會發生異常
def open(fileaddress):
    try:
#透過xlrd模組的open_workbook()方法,開啟一個Excel檔案,定義變數fo為檔案控制程式碼
        fo=xlrd.open_workbook(fileaddress)
        return fo
    except Exception as e:
        print("error!"+str(e))
#定義函式,得到某一個Excel檔案下某一個標籤的行數
def getrows(fo,num):
    table=fo.sheets()[num]
#sheets()函式為xlrd模組自帶函式,能以列表的形式返回該Excel檔案的標籤
    n=table.nrows
#nrows為xlrd模組自帶函式,透過某一個標籤呼叫,可得到該標籤的行數
    return n
"""
定義函式,可透過Excel檔案路徑和標籤的序列編號得到
任意Excel檔案任意標籤的內容,且以列表的形式返回
"""
def getsheetcontents(fileaddress,num):
    avalue=[]
    fo=open(fileaddress)
    table=fo.sheets()[num]
    n=table.nrows
    for i in range(0,n):
        """
        row_values()函式為xlrd模組自帶函式,透過某一個標籤呼叫,
        可得到該標籤的行資料,且這些行資料以列表形式返回,標籤中
        一列為一個列表的元素
        """
        rdate=table.row_values(i)
        avalue.append(rdate)
    return avalue
svalue=[]
k=[]
#透過for迴圈得到所有Excel檔案的標籤數,且以列表的形式返回
for i in a:
    fo=open(i)
    k.append(len(fo.sheets()))
#對這些標籤數進行升序排序
k.sort()
#透過for迴圈把這些Excel檔案中不同標籤的所有內容放在列表svalue中
for i in range(0,k[len(k)-1]):
#透過for迴圈把不同Excel檔案的同一個標籤放在列表bvalue中
    bvalue=[]
    for j in a:
        print("正在讀取"+str(j)+"的第"+str(i)+"個標籤")
        bvalue.append(getsheetcontents(j,i))
    svalue.append(bvalue)
#svalue裡面就是所有Excel檔案的內容
 
#透過xlwt模組的Workbook()建立一個.xls檔案,定義一個變數fw為檔案控制程式碼
fw=xlwt.Workbook()
line=0
#add_sheet()函式為xlwt模組自帶函式,可得到一個自定義標籤
#定義變數ws為標籤控制程式碼
ws=fw.add_sheet("sheet1")
"""
透過for迴圈遍歷svalue列表,把最終得到的
某個標籤某個檔案某行某列的資料寫入新標籤中
"""
for i in range(0,len(svalue)):
    for j in range(0,len(svalue[i])):
        for m in range(0,len(svalue[i][j])):
            for n in range(0,len(svalue[i][j][m])):
                ws.write(line,n,svalue[i][j][m][n])
#透過line可得到不斷增加的行數
            line+=1
print("合併完成")
#save()函式為xlwt自帶函式,將合併好的Excel檔案儲存到某個路徑下
fw.save(b)
#xlrd模組和xlwt模組都沒有close()函式,即用這兩個模組開啟檔案不用關閉檔案

以上就是Python對多個sheet表進行整合的方法,希望對大家有所幫助。更多Python學習指路:

本文教程操作環境:windows7系統、Python 3.9.1,DELL G3電腦。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/2618/viewspace-2829786/,如需轉載,請註明出處,否則將追究法律責任。

相關文章