日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

使用Python批量处理工作簿和工作表

發布時間:2025/3/19 python 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 使用Python批量处理工作簿和工作表 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

使用Python批量處理工作簿和工作表

  • 批量新建并保存工作簿
  • 批量打開一個文件夾中的打開工作簿
  • 批量重命名一個工作簿的所有工作表
  • 批量重命名多個工作簿
  • 批量重命名多個工作簿中的同名工作表
  • 將一個工作簿的所有工作表批量復制到其他工作簿
  • 按條件將一個工作表拆分為多個工作簿

批量新建并保存工作簿

代碼

import xlwings as xw # 啟動 Excel,但不新建工作簿 app = xw.App(visible=True,add_book=False)for i in range(5):#新建工作簿workbook = app.books.add()#保存工作簿workbook.save(f'test{i}.xlsx')#將工作簿關閉workbook.close()

批量打開一個文件夾中的打開工作簿

import xlwings as xw import os # 給出工作簿所在的文件夾路徑 path_file = r'E:/python1/python_module' # 列出該文件夾中所有的子文件或子文件夾 file_list = os.listdir(path_file) # 啟動Excel app = xw.App(visible=True,add_book=False)for i in file_list:# 判斷文件是否為 Excel文件if os.path.splitext(i)[1] =='.xlsx':#打開app.books.open(i)

批量重命名一個工作簿的所有工作表

import xlwings as xw# 啟動Excel app = xw.App(visible=True,add_book=False) # 打開工作簿 workbook = app.books.open('table.xlsx') #獲取工作簿的所有工作表 worhsheets = workbook.sheetsfor i in range(len(worhsheets)):# 重命名工作表worhsheets[i].name = worhsheets[i].name.replace('銷售','') #另存重命名后的工作簿 workbook.save('table1.xlsx') #退出Excel程序 app.quit()

批量重命名多個工作簿

不過這是有前提條件的,要重命名的工作簿名必
須是有規律的,如表1、表2、表3;或者含有相同的關鍵字。

import xlwings as xw import os # 給出工作簿所在的文件夾路徑 path_file = r'E:/python1/python_module' # 列出該文件夾中所有的子文件或子文件夾 file_list = os.listdir(path_file) old_book_name = '銷售表' new_book_name = '分部銷售表' # 啟動Excel app = xw.App(visible=True,add_book=False)for i in file_list:if i.startswith('~$'):continue# 執行查找和替換,生成新的工作簿名new_file = i.replace(old_book_name,new_book_name)# 構造需要重命名工作簿的完整路徑old_path_filr = os.path.join(path_file,i)#構建重命名后工作簿的完整路徑new_path_file = os.path.join(path_file,new_file)# 重命名os.rename(old_path_filr,new_path_file)

if i.startswith(’~$’):
continue

因為Excel會在使用過程中生成一些文件名以"~$"開頭的臨時文件,如果有這些文件就跳過。

批量重命名多個工作簿中的同名工作表

步驟

  • 打印出文件夾中所有子文件的名稱
  • 與文件夾路徑拼接成完整的文件名后,打開
  • 遍歷文件中的所有工作表,如果名字相同就更改
  • 保存工作表目錄
  • 代碼:

    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)# 打開工作簿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()

    將一個工作簿的所有工作表批量復制到其他工作簿

    步驟:

  • 獲取目標(復制到的)文件夾的所有子文件
  • 打開源文件(被復制的),并獲取其所有的工作表信息。
  • 遍歷所有的子文件,如果是Excel文件就打開
  • 在目標工作簿中新增工作表
  • 將來源工作表的數據寫入新增工作表中
  • 代碼

    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('來源工作簿路徑') worksheet = workbook.sheets# 子文件 for i in path_file:if os.path.splitext(i)[1] =='.xlsx':# 打開工作簿workbooks = app.books.open(path_file+'/'+i)# 遍歷工作表for j in worksheet:# 讀取工作表中的信息contents = j.range('A1').expand('table').value# 讀取工作表的名稱name = j.name# 增加同名的工作表workbooks.sheets.add(name = name,after = len(workbooks.sheets))# 寫入數據workbooks.sheets[name].range('A1').value = contents# 保存工作簿workbook.save() app.quit()

    .expand()是xlwings模塊中的函數,用于擴展選擇范圍。語法格式如下

    expand(mode) 默認值是 ‘table’,表示向整個數據表擴展。也可以是’down’(下方)或’right’(右方)

    按條件將一個工作表拆分為多個工作簿

    import os import xlwings as xwfilr_path = 'e:\\table\\產品統計表.xlsx' sheet_name = '統計表'app = xw.App(visible = True ,add_book= False) # 打開工作簿 workbooh = app.books.open(filr_path) # 獲取指定的工作表 worksheet = workbooh.sheets[sheet_name] # 讀取工作表中的所有信息 value = worksheet.range('A2').expand('table').value # 創建一個空字典用于按產品名稱來分類存放數據 data = dict() #按行遍歷工作表數據 for i in range(len(value)):# 獲取當前行的第一個空格中的數據product_name = value[i][1]# 如果沒有該產品if product_name not in data:# 創建一個與當前行名稱對應的空列表data[product_name] = []# 將當前數據追加當列表中data[product_name].append(value[i])for key,value in data.items():# 新建目標工作簿new_workbook = app.books.add()#新建工作表new_sheet = new_workbook.sheets.add(key)# 將要拆分的工作表的列標題復制到新建的工作表中new_sheet['A1'].value = worksheet['A1:H1'].value# 將數據復制new_sheet['A2'].value = valuenew_workbook.save('{}.xlsx'.format(key))app.quit()

    總結

    以上是生活随笔為你收集整理的使用Python批量处理工作簿和工作表的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。