欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python批量處理工作簿和工作表的實現(xiàn)示例

 更新時間:2021年09月06日 09:32:52   作者:落春只在無意間  
本文主要介紹了使用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')
    #將工作簿關(guān)閉
    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.sheets

for i in range(len(worhsheets)):
    # 重命名工作表
    worhsheets[i].name = worhsheets[i].name.replace('銷售','')
#另存重命名后的工作簿
workbook.save('table1.xlsx')
#退出Excel程序
app.quit()

批量重命名多個工作簿

不過這是有前提條件的,要重命名的工作簿名必
須是有規(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 = '銷售表'
new_book_name = '分部銷售表'
# 啟動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

因為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文件就打開
  • 在目標工作簿中新增工作表
  • 將來源工作表的數(shù)據(jù)寫入新增工作表中

代碼

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))
            # 寫入數(shù)據(jù)
            workbooks.sheets[name].range('A1').value = contents
        # 保存工作簿
        workbook.save()
app.quit()

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

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

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

import  os
import xlwings as xw

filr_path = 'e:\\table\\產(chǎn)品統(tǒng)計表.xlsx'
sheet_name = '統(tǒng)計表'

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
# 創(chuàng)建一個空字典用于按產(chǎn)品名稱來分類存放數(shù)據(jù)
data = dict()
#按行遍歷工作表數(shù)據(jù)
for i in range(len(value)):
    # 獲取當前行的第一個空格中的數(shù)據(jù)
    product_name = value[i][1]
    # 如果沒有該產(chǎn)品
    if product_name not in data:
        # 創(chuàng)建一個與當前行名稱對應的空列表
        data[product_name] = []
    # 將當前數(shù)據(jù)追加當列表中
    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
    # 將數(shù)據(jù)復制
    new_sheet['A2'].value = value
    new_workbook.save('{}.xlsx'.format(key))

app.quit()

到此這篇關(guān)于Python批量處理工作簿和工作表的實現(xiàn)示例的文章就介紹到這了,更多相關(guān)Python批量處理工作簿和工作表內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python?pycharm中使用opencv時沒有代碼自動補全提示的解決方案

    python?pycharm中使用opencv時沒有代碼自動補全提示的解決方案

    我們在使用pycharm的時候總是很喜歡其強大的代碼提示功能,下面這篇文章主要給大家介紹了關(guān)于python?pycharm中使用opencv時沒有代碼自動補全提示的解決方案,需要的朋友可以參考下
    2022-09-09
  • Python?并行加速技巧分享

    Python?并行加速技巧分享

    這篇文章主要介紹了Python?并行加速技巧分享,文章圍繞文章主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-05-05
  • python基于http下載視頻或音頻

    python基于http下載視頻或音頻

    這篇文章主要為大家詳細介紹了python基于http下載視頻或音頻,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-06-06
  • python中asyncore異步模塊的實現(xiàn)

    python中asyncore異步模塊的實現(xiàn)

    本文主要介紹了python中asyncore異步模塊的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-01-01
  • 關(guān)于Python使用turtle庫畫任意圖的問題

    關(guān)于Python使用turtle庫畫任意圖的問題

    這篇文章主要介紹了Python turtle庫畫任意圖,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-04-04
  • python實現(xiàn)反轉(zhuǎn)部分單向鏈表

    python實現(xiàn)反轉(zhuǎn)部分單向鏈表

    這篇文章主要為大家詳細介紹了python實現(xiàn)反轉(zhuǎn)部分單向鏈表,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-09-09
  • python排序算法之歸并排序

    python排序算法之歸并排序

    這篇文章主要介紹了python排序算法之歸并排序,歸并排序算法就是一個先把數(shù)列拆分為子數(shù)列,對子數(shù)列進行排序后,再把有序的子數(shù)列合并為完整的有序數(shù)列的算法,需要的朋友可以參考下
    2023-04-04
  • python實現(xiàn)簡易通訊錄修改版

    python實現(xiàn)簡易通訊錄修改版

    這篇文章主要為大家詳細介紹了python實現(xiàn)簡易通訊錄的修改版,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • python將txt文件讀入為np.array的方法

    python將txt文件讀入為np.array的方法

    今天小編就為大家分享一篇python將txt文件讀入為np.array的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10
  • Python實現(xiàn)3行代碼解簡單的一元一次方程

    Python實現(xiàn)3行代碼解簡單的一元一次方程

    這篇文章主要介紹了Python實現(xiàn)3行代碼解簡單的一元一次方程,很適合Python初學者學習借鑒,需要的朋友可以參考下
    2014-08-08

最新評論