校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 如何用python合并多個excel文件

如何用python合并多個excel文件

熱門標簽:crm電銷機器人 電銷機器人 金倫通信 南京crm外呼系統排名 北京外呼電銷機器人招商 汕頭電商外呼系統供應商 賓館能在百度地圖標注嗎 400電話 申請 條件 云南地圖標注 鄭州智能外呼系統中心

安裝模塊

1、找到對應的模塊  http://www.python-excel.org/

2、用 pip install 安裝

pip3 install xlrd
pip3 install XlsxWriter

因為使用的是 python3,所以安裝的時候采用 pip3。

XlsxWriter 示例

先看看簡單的演示:

import xlsxwriter

# 創建一個工作簿并添加一個工作表
workbook = xlsxwriter.Workbook("c.xlsx")
worksheet = workbook.add_worksheet()

# 設置列寬
worksheet.set_column("A:A", 20)

# 設置格式
bold = workbook.add_format({"bold": True})

# 設置單元格的值
worksheet.write("A1", "Hello")

# 帶格式的單元格
worksheet.write("A2", "World")

# 寫一些數字,用行列標識
worksheet.write(2, 0, 123)
worksheet.write(3, 0, 123.456, bold)

# 插入一張圖片
worksheet.insert_image("B5", "s.png")

# 關閉文件流
workbook.close()

運行結果如下:

合并Excel數據

對于合并 excel,有兩種 case ,一種是表頭都是一樣的,一種是表頭不一樣的excel ,但是希望放到同一個表格里面,方便查看

表頭都一樣的 excel

這個處理很簡單,具體代碼如下:

import xlrd
import xlsxwriter

source_xls = ["a.xlsx", "b.xlsx"]
target_xls = "3.xlsx"

# 讀取數據
data = []
for i in c:
 wb = xlrd.open_workbook(i)
 for sheet in wb.sheets():
  for rownum in range(sheet.nrows):
   data.append(sheet.row_values(rownum))
print(data)
# 寫入數據
workbook = xlsxwriter.Workbook(target_xls)
worksheet = workbook.add_worksheet()
font = workbook.add_format({"font_size": 14})
for i in range(len(data)):
 for j in range(len(data[i])):
  worksheet.write(i, j, data[i][j], font)
# 關閉文件流
workbook.close()

Excel 是由行和列組成的,所以這里將所有文件中的所有 sheet 中的數據讀取出來組成一個二維數組,然后再寫入新的 Excel。

表頭都不一樣的 excel

對于表頭不一樣的 excel,可能需要手動選取表格的一部分,然后進行合并。具體代碼如下:

import xlrd
import xlsxwriter

source_xls = ["a.xlsx", "b.xlsx"]
target_xls = "合并.xlsx"

# 讀取數據
data = []
# 重復數據
dupdata = []
# 姓名列表,按照姓名去重
name = []
# 獲取excel的個數
sheetcount = len(source_xls)
i = 0
while i  len(source_xls):
 wb = xlrd.open_workbook(source_xls[i])
 # 存儲不同excel 的數據
 data.append([])
 # 一個excel 可能存在多張表格
 for sheet in wb.sheets():
  if i == 0:
   # 先把表頭添加進去
   dupdata.append(sheet.row_values(0))
  for rownum in range(sheet.nrows):
   # 判斷名字是否重復,表頭都是姓名開頭的,所以把姓名除去
   if (sheet.row_values(rownum)[0] in name):
    dupdata.append(sheet.row_values(rownum))
    # 給數據添加另一個表的表頭
    if (sheet.row_values(rownum)[0] == '姓名'):
     data[i].append(sheet.row_values(rownum))
   else:
    name.append(sheet.row_values(rownum)[0])
    data[i].append(sheet.row_values(rownum))
 i+=1

# 合并數據
workbook = xlsxwriter.Workbook(target_xls)
worksheet = workbook.add_worksheet()
font = workbook.add_format({"font_size": 14})
lineNum = 0
for num in range(len(data)):
 # 區分來自不同excel 的數據
 if num== 0 :
  for i in range(len(data[num])):
   # 姓名
   worksheet.write(lineNum, 0, data[num][i][0], font)
   # 檢查編號
   worksheet.write(lineNum, 1, data[num][i][1], font)
   # 年齡
   worksheet.write(lineNum, 2, data[num][i][23], font)
   # 藍標
   worksheet.write(lineNum, 3, data[num][i][14], font)
   # 黃標
   worksheet.write(lineNum, 4, data[num][i][19], font)
   worksheet.write(lineNum, 5, data[num][i][20], font)
   worksheet.write(lineNum, 6, data[num][i][21], font)
   # 大小
   worksheet.write(lineNum, 7, data[num][i][24], font)
   worksheet.write(lineNum, 8, data[num][i][25], font)
   worksheet.write(lineNum, 9, data[num][i][26], font)
  
   lineNum += 1
 # 只有兩個excel ,所以直接用了 else 
 else:
  for i in range(len(data[num])):
   lineNum += 1
   # 姓名
   worksheet.write(lineNum, 0, data[num][i][0], font)
   # 檢查編號
   worksheet.write(lineNum, 1, data[num][i][1], font)
   # 年齡
   worksheet.write(lineNum, 2, data[num][i][2], font)
   # 藍標
   worksheet.write(lineNum, 3, data[num][i][30], font)
# 關閉文件流
workbook.close()

# 針對重復數據,連表頭一起輸出,方便后續回顧查看
workbook = xlsxwriter.Workbook("重復.xlsx")
worksheet = workbook.add_worksheet()
font = workbook.add_format({"font_size": 14})
for i in range(len(dupdata)):
 for j in range(len(dupdata[i])):
  worksheet.write(i, j, dupdata[i][j], font)
# 關閉文件流
workbook.close()

Excel 是由行和列組成的,所以這里將所有文件中的所有 sheet 中的數據讀取出來組成一個二維數組,然后再寫入新的 Excel。

表頭都不一樣的 excel

對于表頭不一樣的 excel,可能需要手動選取表格的一部分,然后進行合并。具體代碼如下:

import xlrd
import xlsxwriter

source_xls = ["a.xlsx", "b.xlsx"]
target_xls = "合并.xlsx"

# 讀取數據
data = []
# 重復數據
dupdata = []
# 姓名列表,按照姓名去重
name = []
# 獲取excel的個數
sheetcount = len(source_xls)
i = 0
while i  len(source_xls):
 wb = xlrd.open_workbook(source_xls[i])
 # 存儲不同excel 的數據
 data.append([])
 # 一個excel 可能存在多張表格
 for sheet in wb.sheets():
  if i == 0:
   # 先把表頭添加進去
   dupdata.append(sheet.row_values(0))
  for rownum in range(sheet.nrows):
   # 判斷名字是否重復,表頭都是姓名開頭的,所以把姓名除去
   if (sheet.row_values(rownum)[0] in name):
    dupdata.append(sheet.row_values(rownum))
    # 給數據添加另一個表的表頭
    if (sheet.row_values(rownum)[0] == '姓名'):
     data[i].append(sheet.row_values(rownum))
   else:
    name.append(sheet.row_values(rownum)[0])
    data[i].append(sheet.row_values(rownum))
 i+=1

# 合并數據
workbook = xlsxwriter.Workbook(target_xls)
worksheet = workbook.add_worksheet()
font = workbook.add_format({"font_size": 14})
lineNum = 0
for num in range(len(data)):
 # 區分來自不同excel 的數據
 if num== 0 :
  for i in range(len(data[num])):
   # 姓名
   worksheet.write(lineNum, 0, data[num][i][0], font)
   # 檢查編號
   worksheet.write(lineNum, 1, data[num][i][1], font)
   # 年齡
   worksheet.write(lineNum, 2, data[num][i][23], font)
   # 藍標
   worksheet.write(lineNum, 3, data[num][i][14], font)
   # 黃標
   worksheet.write(lineNum, 4, data[num][i][19], font)
   worksheet.write(lineNum, 5, data[num][i][20], font)
   worksheet.write(lineNum, 6, data[num][i][21], font)
   # 大小
   worksheet.write(lineNum, 7, data[num][i][24], font)
   worksheet.write(lineNum, 8, data[num][i][25], font)
   worksheet.write(lineNum, 9, data[num][i][26], font)
  
   lineNum += 1
 # 只有兩個excel ,所以直接用了 else 
 else:
  for i in range(len(data[num])):
   lineNum += 1
   # 姓名
   worksheet.write(lineNum, 0, data[num][i][0], font)
   # 檢查編號
   worksheet.write(lineNum, 1, data[num][i][1], font)
   # 年齡
   worksheet.write(lineNum, 2, data[num][i][2], font)
   # 藍標
   worksheet.write(lineNum, 3, data[num][i][30], font)
# 關閉文件流
workbook.close()

# 針對重復數據,連表頭一起輸出,方便后續回顧查看
workbook = xlsxwriter.Workbook("重復.xlsx")
worksheet = workbook.add_worksheet()
font = workbook.add_format({"font_size": 14})
for i in range(len(dupdata)):
 for j in range(len(dupdata[i])):
  worksheet.write(i, j, dupdata[i][j], font)
# 關閉文件流
workbook.close()

合并后的結果

重復列表結果如下:

以上就是如何用python合并多個excel文件的詳細內容,更多關于python 合并excel文件的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • python合并多個excel文件的示例
  • 使用python將多個excel文件合并到同一個文件的方法
  • 使用Python橫向合并excel文件的實例
  • Python批量合并有合并單元格的Excel文件詳解
  • Python將多個excel文件合并為一個文件
  • 使用Python快速打開一個百萬行級別的超大Excel文件的方法
  • 淺談Python xlwings 讀取Excel文件的正確姿勢
  • Python3利用openpyxl讀寫Excel文件的方法實例
  • 基于Python的接口自動化讀寫excel文件的方法
  • python基于openpyxl生成excel文件
  • Python xlrd/xlwt 創建excel文件及常用操作
  • 教你用Python代碼實現合并excel文件

標簽:石家莊 昆明 錫林郭勒盟 西寧 懷化 浙江 文山 梅州

巨人網絡通訊聲明:本文標題《如何用python合并多個excel文件》,本文關鍵詞  如,何用,python,合并,多個,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《如何用python合并多個excel文件》相關的同類信息!
  • 本頁收集關于如何用python合并多個excel文件的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    国产在线一区二区| 欧美在线三级电影| 91国偷自产一区二区三区成为亚洲经典| 成人av先锋影音| 欧美精三区欧美精三区| 在线不卡a资源高清| 精品国内片67194| 亚洲综合激情另类小说区| 麻豆精品久久久| av一二三不卡影片| 欧美成人精品二区三区99精品| 久久久久久久久久看片| 国产精品成人免费| 九九**精品视频免费播放| 99久久婷婷国产综合精品| 日韩一区国产二区欧美三区| 欧美激情一区在线| 一区二区三区欧美日韩| 亚洲韩国精品一区| 不卡av在线免费观看| 欧美成人午夜电影| 国产精品高潮呻吟久久| 精品一区二区三区免费播放| 欧洲生活片亚洲生活在线观看| 久久久不卡网国产精品一区| 亚洲国产中文字幕| 成人激情综合网站| 91精品午夜视频| 亚洲国产精品一区二区尤物区| 丰满白嫩尤物一区二区| 精品久久久久一区| 亚洲v中文字幕| 一本大道久久a久久精品综合| 久久精品人人做| 久久精品国产免费看久久精品| 精品视频在线看| 亚洲激情欧美激情| 91年精品国产| 专区另类欧美日韩| 成人激情免费视频| 国产女人18毛片水真多成人如厕 | 亚洲男女一区二区三区| 国内精品自线一区二区三区视频| 色哟哟一区二区在线观看| 中文字幕中文字幕一区| 国产成人日日夜夜| 精品精品国产高清一毛片一天堂| 亚洲免费三区一区二区| 91视频免费观看| 亚洲美女视频在线| 在线视频中文字幕一区二区| 亚洲综合色丁香婷婷六月图片| 国产盗摄视频一区二区三区| 精品国产乱码久久久久久免费| 老司机精品视频在线| 日韩一区二区精品| 久久66热re国产| 国产网红主播福利一区二区| 岛国精品在线观看| 中文字幕一区三区| 91视频免费观看| 一区二区免费在线| 欧美高清激情brazzers| 久久国产生活片100| 久久蜜桃一区二区| 成人avav影音| 亚洲成人av一区二区三区| 欧美伦理视频网站| 国产一区二区不卡老阿姨| 国产精品青草综合久久久久99| 暴力调教一区二区三区| 一区二区在线观看不卡| 日韩一级免费一区| 国产很黄免费观看久久| 亚洲免费大片在线观看| 制服丝袜av成人在线看| 国产一区不卡精品| 国产蜜臀97一区二区三区| 欧洲一区二区三区免费视频| 蜜臂av日日欢夜夜爽一区| 国产欧美精品区一区二区三区| 91成人网在线| 精品一区二区三区的国产在线播放 | 国产日韩一级二级三级| 色一区在线观看| 蜜桃av噜噜一区| 亚洲人成7777| 久久新电视剧免费观看| 成人av电影在线| 日韩电影一区二区三区四区| 久久免费美女视频| 欧美在线free| 97精品久久久午夜一区二区三区| 国产一区二区在线影院| 日韩二区三区四区| 午夜视频一区二区| 亚洲一卡二卡三卡四卡无卡久久| 欧美高清在线一区| 欧美韩国日本不卡| 久久一留热品黄| 欧美精品一区二区三区很污很色的| 在线播放国产精品二区一二区四区 | 欧美中文字幕一区二区三区亚洲| 国产白丝网站精品污在线入口| 久国产精品韩国三级视频| 日本欧美肥老太交大片| 亚洲一区二区欧美激情| 亚洲男人的天堂在线观看| 自拍偷拍国产精品| 日韩美女视频19| 一区二区视频在线看| 一区二区三区在线免费观看| 亚洲欧美视频一区| 尤物视频一区二区| 亚洲女同ⅹxx女同tv| 亚洲另类春色国产| 亚洲午夜免费视频| 天天影视涩香欲综合网| 天天免费综合色| 日韩av电影天堂| 日本少妇一区二区| 久久成人麻豆午夜电影| 韩国av一区二区三区| 国产久卡久卡久卡久卡视频精品| 国产乱码一区二区三区| 成人在线视频一区二区| 99视频精品在线| 在线亚洲欧美专区二区| 欧美日韩免费观看一区三区| 67194成人在线观看| 欧美大片顶级少妇| 日本一区二区免费在线观看视频| 国产精品乱人伦一区二区| 亚洲丝袜制服诱惑| 日韩综合一区二区| 久久66热re国产| av在线这里只有精品| 色视频欧美一区二区三区| 欧美日韩在线播| 精品国产三级a在线观看| 国产精品国产三级国产普通话蜜臀| 亚洲乱码日产精品bd| 日本在线观看不卡视频| 国产成人精品一区二区三区网站观看| 成人三级伦理片| 欧美日韩亚洲综合一区二区三区| 日韩精品专区在线影院观看| 欧美激情综合五月色丁香小说| 亚洲日本青草视频在线怡红院| 亚洲成人777| 国产乱码精品1区2区3区| 色哟哟国产精品| 精品国产欧美一区二区| 一区二区三区不卡视频在线观看| 蜜臀久久99精品久久久久宅男| voyeur盗摄精品| 欧美精品成人一区二区三区四区| 国产亚洲精品福利| 午夜视频久久久久久| 国产高清不卡一区二区| 欧美日韩一级视频| 国产精品理论在线观看| 91尤物视频在线观看| 精品国产免费久久| 亚洲成人动漫一区| 成人精品视频一区二区三区 | 91黄色免费看| 久久久久国产成人精品亚洲午夜| 亚洲国产一区二区视频| 高清在线不卡av| 欧美成人精品福利| 亚洲成在人线免费| 福利91精品一区二区三区| 欧美一区二区三区在线看| 日韩精品三区四区| 色综合久久久久综合体桃花网| 久久综合狠狠综合久久激情| 午夜免费久久看| 色94色欧美sute亚洲线路一ni| 国产日韩在线不卡| 精一区二区三区| 欧美二区在线观看| 亚洲成人一区二区在线观看| 99国产精品久久久久久久久久久 | 欧美绝品在线观看成人午夜影视| 中国av一区二区三区| 精品一二三四区| 欧美成人女星排行榜| 日韩精品一级中文字幕精品视频免费观看 | 中文字幕精品一区二区精品绿巨人| 日韩精品91亚洲二区在线观看 | 日日夜夜精品视频免费| 在线亚洲精品福利网址导航| 亚洲人亚洲人成电影网站色| 国产.精品.日韩.另类.中文.在线.播放| 日韩欧美亚洲国产精品字幕久久久| 婷婷夜色潮精品综合在线| 欧美日韩一级黄| 日本在线播放一区二区三区| 91精品国模一区二区三区|