Python批量處理工作簿和工作表的實(shí)現(xiàn)示例
批量新建并保存工作簿
代碼
import xlwings as xw
# 啟動(dòng) Excel,但不新建工作簿
app = xw.App(visible=True,add_book=False)
for i in range(5):
#新建工作簿
workbook = app.books.add()
#保存工作簿
workbook.save(f'test{i}.xlsx')
#將工作簿關(guān)閉
workbook.close()
批量打開(kāi)一個(gè)文件夾中的打開(kāi)工作簿
import xlwings as xw
import os
# 給出工作簿所在的文件夾路徑
path_file = r'E:/python1/python_module'
# 列出該文件夾中所有的子文件或子文件夾
file_list = os.listdir(path_file)
# 啟動(dòng)Excel
app = xw.App(visible=True,add_book=False)
for i in file_list:
# 判斷文件是否為 Excel文件
if os.path.splitext(i)[1] =='.xlsx':
#打開(kāi)
app.books.open(i)
批量重命名一個(gè)工作簿的所有工作表
import xlwings as xw
# 啟動(dòng)Excel
app = xw.App(visible=True,add_book=False)
# 打開(kāi)工作簿
workbook = app.books.open('table.xlsx')
#獲取工作簿的所有工作表
worhsheets = workbook.sheets
for i in range(len(worhsheets)):
# 重命名工作表
worhsheets[i].name = worhsheets[i].name.replace('銷(xiāo)售','')
#另存重命名后的工作簿
workbook.save('table1.xlsx')
#退出Excel程序
app.quit()
批量重命名多個(gè)工作簿
不過(guò)這是有前提條件的,要重命名的工作簿名必
須是有規(guī)律的,如表1、表2、表3;或者含有相同的關(guān)鍵字。
import xlwings as xw
import os
# 給出工作簿所在的文件夾路徑
path_file = r'E:/python1/python_module'
# 列出該文件夾中所有的子文件或子文件夾
file_list = os.listdir(path_file)
old_book_name = '銷(xiāo)售表'
new_book_name = '分部銷(xiāo)售表'
# 啟動(dòng)Excel
app = xw.App(visible=True,add_book=False)
for i in file_list:
if i.startswith('~$'):
continue
# 執(zhí)行查找和替換,生成新的工作簿名
new_file = i.replace(old_book_name,new_book_name)
# 構(gòu)造需要重命名工作簿的完整路徑
old_path_filr = os.path.join(path_file,i)
#構(gòu)建重命名后工作簿的完整路徑
new_path_file = os.path.join(path_file,new_file)
# 重命名
os.rename(old_path_filr,new_path_file)
if i.startswith('~$'):
continue
因?yàn)镋xcel會(huì)在使用過(guò)程中生成一些文件名以"~$"開(kāi)頭的臨時(shí)文件,如果有這些文件就跳過(guò)。
批量重命名多個(gè)工作簿中的同名工作表
步驟
- 打印出文件夾中所有子文件的名稱(chēng)
- 與文件夾路徑拼接成完整的文件名后,打開(kāi)
- 遍歷文件中的所有工作表,如果名字相同就更改
- 保存工作表目錄
代碼:
import xlwings as xw
import os
# 給出工作簿所在的文件夾路徑
path_file = r'E:/python1/python_module'
# 列出該文件夾中所有的子文件或子文件夾
file_list = os.listdir(path_file)
old_sheet = 'sheet1'
new_sheet = '員工信息'
app = xw.App(visible=True,add_book= False)
# 遍歷工作簿
for i in path_file:
if i.startswith('~$'):
continue
# 拼接出完整路徑
old_path_file = os.path.join(path_file,i)
# 打開(kāi)工作簿
workbook = app.books.open(old_path_file)
# 遍歷工作表
for j in workbook.sheets:
if j.name == old_sheet:
j.name = new_sheet
# 保存工作簿
workbook.save()
app.quit()
將一個(gè)工作簿的所有工作表批量復(fù)制到其他工作簿
步驟:
- 獲取目標(biāo)(復(fù)制到的)文件夾的所有子文件
- 打開(kāi)源文件(被復(fù)制的),并獲取其所有的工作表信息。
- 遍歷所有的子文件,如果是Excel文件就打開(kāi)
- 在目標(biāo)工作簿中新增工作表
- 將來(lái)源工作表的數(shù)據(jù)寫(xiě)入新增工作表中
代碼
import xlwings as xw
import os
# 給出工作簿所在的文件夾路徑
path_file = r'E:/python1/python_module'
# 列出該文件夾中所有的子文件或子文件夾
file_list = os.listdir(path_file)
app = xw.App(visible=True,add_book= False)
workbook = app.books.open('來(lái)源工作簿路徑')
worksheet = workbook.sheets
# 子文件
for i in path_file:
if os.path.splitext(i)[1] =='.xlsx':
# 打開(kāi)工作簿
workbooks = app.books.open(path_file+'/'+i)
# 遍歷工作表
for j in worksheet:
# 讀取工作表中的信息
contents = j.range('A1').expand('table').value
# 讀取工作表的名稱(chēng)
name = j.name
# 增加同名的工作表
workbooks.sheets.add(name = name,after = len(workbooks.sheets))
# 寫(xiě)入數(shù)據(jù)
workbooks.sheets[name].range('A1').value = contents
# 保存工作簿
workbook.save()
app.quit()
.expand()是xlwings模塊中的函數(shù),用于擴(kuò)展選擇范圍。語(yǔ)法格式如下
expand(mode) 默認(rèn)值是 ‘table',表示向整個(gè)數(shù)據(jù)表擴(kuò)展。也可以是'down'(下方)或'right'(右方)
按條件將一個(gè)工作表拆分為多個(gè)工作簿
import os
import xlwings as xw
filr_path = 'e:\\table\\產(chǎn)品統(tǒng)計(jì)表.xlsx'
sheet_name = '統(tǒng)計(jì)表'
app = xw.App(visible = True ,add_book= False)
# 打開(kāi)工作簿
workbooh = app.books.open(filr_path)
# 獲取指定的工作表
worksheet = workbooh.sheets[sheet_name]
# 讀取工作表中的所有信息
value = worksheet.range('A2').expand('table').value
# 創(chuàng)建一個(gè)空字典用于按產(chǎn)品名稱(chēng)來(lái)分類(lèi)存放數(shù)據(jù)
data = dict()
#按行遍歷工作表數(shù)據(jù)
for i in range(len(value)):
# 獲取當(dāng)前行的第一個(gè)空格中的數(shù)據(jù)
product_name = value[i][1]
# 如果沒(méi)有該產(chǎn)品
if product_name not in data:
# 創(chuàng)建一個(gè)與當(dāng)前行名稱(chēng)對(duì)應(yīng)的空列表
data[product_name] = []
# 將當(dāng)前數(shù)據(jù)追加當(dāng)列表中
data[product_name].append(value[i])
for key,value in data.items():
# 新建目標(biāo)工作簿
new_workbook = app.books.add()
#新建工作表
new_sheet = new_workbook.sheets.add(key)
# 將要拆分的工作表的列標(biāo)題復(fù)制到新建的工作表中
new_sheet['A1'].value = worksheet['A1:H1'].value
# 將數(shù)據(jù)復(fù)制
new_sheet['A2'].value = value
new_workbook.save('{}.xlsx'.format(key))
app.quit()
到此這篇關(guān)于Python批量處理工作簿和工作表的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Python批量處理工作簿和工作表內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
利用Python3分析sitemap.xml并抓取導(dǎo)出全站鏈接詳解
因?yàn)樽罱鼡Q了網(wǎng)址,所以需要在百度站長(zhǎng)平臺(tái)提交網(wǎng)址,不管是主動(dòng)推送還是手動(dòng)提交,前提都是要整理網(wǎng)站的鏈接,手動(dòng)添加太麻煩,于是就想寫(xiě)個(gè)腳本直接抓取全站鏈接并導(dǎo)出,本文詳細(xì)介紹的是實(shí)現(xiàn)的方法及過(guò)程,需要的朋友們一起來(lái)看看吧。2017-07-07
Python中使用HTMLParser解析html實(shí)例
這篇文章主要介紹了Python中使用HTMLParser解析html實(shí)例,本文直接給出使用示例,并總結(jié)出HTMLParser含有的方法分為兩類(lèi),一類(lèi)是需要顯式調(diào)用的,而另一類(lèi)不需顯示調(diào)用,需要的朋友可以參考下2015-02-02
Django之Mode的外鍵自關(guān)聯(lián)和引用未定義的Model方法
今天小編就為大家分享一篇Django之Mode的外鍵自關(guān)聯(lián)和引用未定義的Model方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-12-12
Python2及Python3如何實(shí)現(xiàn)兼容切換
這篇文章主要介紹了Python2及Python3如何實(shí)現(xiàn)兼容切換,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09
解決運(yùn)行django程序出錯(cuò)問(wèn)題 ''str''object has no attribute''_meta''
這篇文章主要介紹了解決運(yùn)行django程序出錯(cuò)問(wèn)題 'str'object has no attribute'_meta',具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07
Python獲取任意xml節(jié)點(diǎn)值的方法
這篇文章主要介紹了Python獲取任意xml節(jié)點(diǎn)值的方法,涉及Python操作XML節(jié)點(diǎn)的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-05-05

