python不到50行代碼完成了多張excel合并的實(shí)現(xiàn)示例
一 前言
公司同事最近在做excel相關(guān)的工作;今天來求助知識(shí)追尋者合并多個(gè)excel為一個(gè)一個(gè)工作本,原本是java操作poi太蛋疼了,笨重不堪,內(nèi)存消耗嚴(yán)重,知識(shí)追尋者使用python不到40行代碼完成了60多張excel工作本合并為一張;python真香
牛皮吹完了,如果看過知識(shí)追尋者系列文章的讀者肯定知道之前知識(shí)追尋者發(fā)過一篇
python專題使用openpyxl操作excel;本篇使用的不是openpyx庫,使用的使是xlrd,xlwt庫,雖然這兩庫功能沒法根openpyx相比,但可以操作xls結(jié)尾的舊版excel而openpyx不支持;
二 代碼
大體思路如下
- 遍歷獲取根目錄下的所有excel文件
- 根據(jù)excel名稱進(jìn)行匹配獲取某類excel
- 創(chuàng)建工作本用于寫入拷貝的數(shù)據(jù)
- 每個(gè)excel都有一張Sheet1,循環(huán)遍歷單元格寫入創(chuàng)建的工作本
詳細(xì)過程寫在代碼里面;讀者可以參考一下思路和使用方式,后續(xù)知識(shí)追尋者有空會(huì)出這2庫基礎(chǔ)系列文章的使用方式;
# -*- coding: utf-8 -*-
import xlrd
import xlwt
import os
import re
""" 寫入工作本 """
def write_excel(path, write_sheet):
# 加載工作本
book = xlrd.open_workbook(path)
# 獲取表單
read_sheet = book.sheet_by_name('Sheet1')
# 遍歷
for row in range(read_sheet.nrows):
for col in range(read_sheet.ncols):
write_sheet.write(row, col, read_sheet.cell_value(row,col))
# 獲取根目錄下所有文件名
def walk(path):
for root,dirs,names in os.walk(path):
list = []
for filename in names:
path = os.path.join(root, filename)
list.append(path)
return list
if __name__ == "__main__":
# 創(chuàng)建工作本
write_book = xlwt.Workbook()
# 根目錄
root = r'C:\mydata\generator\excel'
path_list = walk(root)
for path in path_list:
val = path.find("本???)
if val!=-1:
# 正則匹配
ser = re.search('.*20200403(.*?).xls',path)
name = ser.group(1)
# 創(chuàng)建sheet
write_sheet = write_book.add_sheet(name)
# 寫入
write_excel(path, write_sheet)
# 保存
write_book.save(r'本???xls')
到此這篇關(guān)于python不到50行代碼完成了多張excel合并的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)python 多張excel合并內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 利用Python pandas對(duì)Excel進(jìn)行合并的方法示例
- python合并多個(gè)excel文件的示例
- Python調(diào)用接口合并Excel表代碼實(shí)例
- 使用 Python 合并多個(gè)格式一致的 Excel 文件(推薦)
- Python pandas實(shí)現(xiàn)excel工作表合并功能詳解
- python操作openpyxl導(dǎo)出Excel 設(shè)置單元格格式及合并處理代碼實(shí)例
- 使用python將多個(gè)excel文件合并到同一個(gè)文件的方法
- python 實(shí)現(xiàn)讀取一個(gè)excel多個(gè)sheet表并合并的方法
- Python批量合并有合并單元格的Excel文件詳解
- python之DataFrame實(shí)現(xiàn)excel合并單元格
- python excel多行合并的方法
相關(guān)文章
caffe的python接口caffemodel參數(shù)及特征抽取示例
這篇文章主要介紹了caffe的python接口caffemodel參數(shù)及特征抽取示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06
Python中的Logging模塊在項(xiàng)目應(yīng)用小結(jié)
Python標(biāo)準(zhǔn)庫中的logging模塊為我們提供了強(qiáng)大而靈活的日志記錄功能,本文將介紹如何使用logging模塊,并探討其在Python開發(fā)中的實(shí)際應(yīng)用,感興趣的朋友一起看看吧2024-04-04
Python基于hashlib模塊的文件MD5一致性加密驗(yàn)證示例
這篇文章主要介紹了Python基于hashlib模塊的文件MD5一致性加密驗(yàn)證,涉及Python使用hashlib模塊進(jìn)行字符串與文件的MD5加密驗(yàn)證操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-02-02
Python實(shí)現(xiàn)隨機(jī)選擇元素功能
這篇文章主要為大家詳細(xì)介紹了Python實(shí)現(xiàn)隨機(jī)選擇元素功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-09-09
對(duì)python numpy.array插入一行或一列的方法詳解
今天小編就為大家分享一篇對(duì)python numpy.array插入一行或一列的方法詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-01-01
利用Python實(shí)現(xiàn)快速批量轉(zhuǎn)換HEIC文件
HEIC 是蘋果采用的新的默認(rèn)圖片格式,它能在不損失圖片畫質(zhì)的情況下,減少圖片大小。本篇文章將使用 Python 批量實(shí)現(xiàn) HEIC 圖片文件的格式轉(zhuǎn)換,需要的可以參考一下2022-07-07
Python通過pymysql調(diào)用MySQL進(jìn)行增刪改移查
這篇文章主要介紹了Python通過pymysql調(diào)用MySQL,從而實(shí)現(xiàn)數(shù)據(jù)的增刪改移查功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2021-12-12

