針對不同場景的Python合併多個Excel方法

Python研究者發表於2021-08-10

大家好,我是辰哥~

在辰哥看來,技術能夠減少繁瑣工作帶來的枯燥,技術+實際=方便。最近辰哥也是在弄excel檔案的時候發現手動去整理有點繁瑣枯燥,想著技術可以代替我去處理這部分繁瑣的工作那何樂而不為呢~~~

三種場景

  1. 多個同欄位的excel檔案合併成一個excel

  2. 多個不同欄位的excel檔案拼接成一個excel

  3. 一個excel的多個sheet合併成一個sheet

辰哥目前想到的僅是辰哥遇到的這三種情況(如果還有很多其他情況的,歡迎在下方留言,因為辰哥日常非經常涉及多種excel處理的內容,所以想不到其他情況)

01 合併多個同欄位的excel

這裡辰哥先新建三個excel檔案:11.xlsx;12.xlsx;13.xlsx;並往裡填充資料,資料如下:

11.xlsx

12.xlsx

13.xlsx

需求:將這三個excel檔案合併到一個excel中。

匯入庫

# 讀取模組
import xlrd
# 寫入模組
import xlwt

這裡需要用到兩個庫:xlrd讀取excel; xlwt寫入到合併的excel;

# 檔案列表
xlxs_list = ["1/11.xlsx","1/12.xlsx","1/13.xlsx"]
# 建立合併後的檔案
workbook = xlwt.Workbook(encoding='ascii')
worksheet = workbook.add_sheet('Sheet1')

定義合併哪些excel檔案,以及合併後的excel

# 行數
count = 0
#表頭(只寫入第一個xlsx的表頭)
bt = 0
for name in xlxs_list:
    wb = xlrd.open_workbook(name)
    #按工作簿定位工作表
    sh = wb.sheet_by_name('Sheet1')
    #遍歷excel,列印所有資料
    if count>1:
        bt=1
    for i in range(bt,sh.nrows):
        k = sh.row_values(i)
        # 遍歷每一行中的每一列
        for j in range(0,len(k)):
            worksheet.write(count,j, label=str(k[j]))
        count = count +1
workbook.save('1/合併1_辰哥.xlsx')

最後合併到:**合併1_辰哥.xlsx  **中,其結果如下:

02 拼接多個不同欄位的excel

新建三個excel檔案:21.xlsx;22.xlsx;23.xlsx;並往裡填充資料

21.xlsx

22.xlsx

23.xlsx

將這三個excel檔案拼接帶一個excel中(從左往右)

# 列數
col = 0
for name in xlxs_list:
    wb = xlrd.open_workbook(name)
    #按工作簿定位工作表
    sh = wb.sheet_by_name('Sheet1')
    #遍歷excel,列印所有資料
    for i in range(0,sh.nrows):
        k = sh.row_values(i)
        # 遍歷每一行中的每一列
        for j in range(0,len(k)):
            worksheet.write(i,col+j, label=str(k[j]))
    col = col +len(k)
workbook.save('2/合併2_辰哥.xlsx')

最後合併到:**合併2_辰哥.xlsx  **中,其結果如下:

03 合併一個excel的多個sheet

新建一個excel檔案:31.xlsx;並新增sheet1、sheet2、sheet3,往裡填充資料

sheet1

sheet2

sheet3

將同一個excel檔案中的這三個sheet併到一個sheet中。

sheet_list = ['Sheet1','Sheet2','Sheet3']
# 行數
count = 0
# 表頭(只寫入第一個xlsx的表頭)
bt = 0
for st in sheet_list:
    #按工作簿定位工作表
    sh = wb.sheet_by_name(st)
    #遍歷excel,列印所有資料
    if count > 1:
        bt = 1
    for i in range(bt, sh.nrows):
        k = sh.row_values(i)
        # 遍歷每一行中的每一列
        for j in range(0, len(k)):
            worksheet.write(count, j, label=str(k[j]))
        count = count + 1
workbook.save('3/合併3_辰哥.xlsx')

最後合併到:合併3_辰哥.xlsx 中,其結果如下:

04 小結

目前想到的僅是辰哥遇到的這三種情況(如果還有很多其他情況的,歡迎在下方留言,因為辰哥日常並非經常涉及多種excel處理的內容,所以想不到其他情況)

相關文章