使用Python批量处理工作簿和工作表
生活随笔
收集整理的這篇文章主要介紹了
使用Python批量处理工作簿和工作表
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
使用Python批量處理工作簿和工作表
- 批量新建并保存工作簿
- 批量打開(kāi)一個(gè)文件夾中的打開(kāi)工作簿
- 批量重命名一個(gè)工作簿的所有工作表
- 批量重命名多個(gè)工作簿
- 批量重命名多個(gè)工作簿中的同名工作表
- 將一個(gè)工作簿的所有工作表批量復(fù)制到其他工作簿
- 按條件將一個(gè)工作表拆分為多個(gè)工作簿
批量新建并保存工作簿
代碼
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.sheetsfor 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)鍵字。
if i.startswith(’~$’):
continue
因?yàn)镋xcel會(huì)在使用過(guò)程中生成一些文件名以"~$"開(kāi)頭的臨時(shí)文件,如果有這些文件就跳過(guò)。
批量重命名多個(gè)工作簿中的同名工作表
步驟
代碼:
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ù)制到其他工作簿
步驟:
代碼
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 xwfilr_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 = valuenew_workbook.save('{}.xlsx'.format(key))app.quit()總結(jié)
以上是生活随笔為你收集整理的使用Python批量处理工作簿和工作表的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 模块的交互
- 下一篇: 使用Python批量处理行、列和单元格