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

Python如何操作office實(shí)現(xiàn)自動(dòng)化及win32com.client的運(yùn)用

 更新時(shí)間:2020年04月01日 11:59:36   作者:行走_(dá)  
這篇文章主要介紹了Python如何操作office實(shí)現(xiàn)自動(dòng)化及win32com.client的運(yùn)用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

應(yīng)用背景

工作中,由于需要出定期的report,需要用到office,主要是要用到excel表格,然后給各個(gè)team或者boss發(fā)email report。這里邊就包含了不少重復(fù)性的工作,工作中常常有一個(gè)固定的模板來出report,而每次只需將相關(guān)的數(shù)據(jù)手動(dòng)導(dǎo)入,如果將這些重復(fù)性的動(dòng)作,實(shí)現(xiàn)自動(dòng)化,無疑可以省去不少功夫。于是我就想到了用python來實(shí)現(xiàn)自動(dòng)化生成表格。今天介紹的只是一部分,主要是excel表格自動(dòng)修改生成。

似乎是一個(gè)很簡單的活,調(diào)用常用的與excel相關(guān)的python模塊xlrd, xlwd 或者 openpyxl即可,沒錯(cuò),這些對excel表格進(jìn)行簡單操作都很666,但是我的表格里邊出現(xiàn)了透視表,這讓我非常的痛苦,一下子發(fā)現(xiàn)上邊的三個(gè)模塊不好用,而且用著用著,我還發(fā)現(xiàn),openpyxl似乎是沒有直接刪除行的功能函數(shù),當(dāng)你復(fù)制之前一個(gè)表格為基表,更改一部分內(nèi)容保存后,透視表就消失了,內(nèi)心是很崩潰的,在谷歌、百度上看了不少帖子,也沒有很好的辦法,最后還是stackoverflow上看到一個(gè)帖子里,用到了win32com.client,剛開始看不懂,里邊好多函數(shù)都不知道哪里來的,也沒有文檔。

最后發(fā)現(xiàn),win32com.client可以直接調(diào)用VBA的庫,這可就強(qiáng)大了,VBA是包含record macro功能的,手動(dòng)操作excel直接record,你就可以找到對應(yīng)的函數(shù),然后就可以調(diào)用,一下子很多的功能都實(shí)現(xiàn)了。

實(shí)例

先來看看案例表格:

 

這里只介紹一部分功能實(shí)現(xiàn),也是主要的部分,其余的部分sheet頁操作是類似的,這里會(huì)介紹一部分模塊使用的方法。

第一個(gè)表格,主要需要從內(nèi)部共享的文件夾中,去下載需要的Cases,都是文檔類型的文件,需要將它們寫入到表一中的AllCases列中,這里比較簡單,我們只需要用open和readlines(),用遍歷的方式將其寫入到excel表中即可。然后在表二中,刷新透視表。以下我截取部分的代碼,路徑自己構(gòu)建輸入即可,我將分塊來介紹。

class AutomationReport(object):

  def __init__(self, excel, win32c, folder_src, folder_dst, src, src_G, src_failed, src_flip, filepath):
    self.excel = excel
    self.win32c = win32c
    self.folder_src = folder_src
    self.folder_dst = folder_dst
    self.src = src
    self.src_G = src_G
    self.src_failed = src_failed
    self.src_flip = src_flip
    self.filepath = filepath

   def write_AllCases(self):
     # open one file and write it into excel AllCases sheet
     with open(self.src, 'r') as f:
       wb = self.excel.Workbooks.Open(self.filepath)
       sheet_AllCases = wb.Worksheets('AllCases')
       i = 2
       for case in f.readlines():
         cel = 'K%d' % i
         sheet_AllCases.Range(cel).Value = case.strip()
         i = i + 1

       # open second file and write it into excel AllCases sheet
       with open(self.src_G, 'r') as fg:
         for case in fg.readlines():
           cel = 'K%d' % i
           sheet_AllCases.Range(cel).Value = case.strip()
           i = i + 1

       # copy format or delete redundant content
       cel = 'K%d' % i
       if sheet_AllCases.Range(cel).Value is None:
         rg = "A%s:J%s" % (i-1, i-1)
         selection = sheet_AllCases.Range("A29000:J29000").Select
         selection.AutoFill(Destination=sheet_AllCases.Range(rg), Type=xlFillDefault)

       else:
         # delete redundant content
         while sheet_AllCases.Range(cel).Value is not None:
           sheet_AllCases.Rows(i).Delete()

       wb.Save()


if __name__ == "__main__":

  excel = win32com.client.Dispatch('Excel.Application')
  win32c = win32com.client.constants

  # input your path
  folder_src = ...
  ...
  # Excel table file path
  filepath = ...

  # Object instance and invoke functions
  t = AutomationReport(excel, win32c, folder_src, folder_dst, src, src_G, src_failed, src_flip, filepath)
  t.copyFile()
  t.write_AllCases()
  t.write_ReportRaw()

遍歷文件內(nèi)容

遍歷文件,寫入cases,代碼如下,用win32com.client模塊(self.excel)打開我們需要修改的表格文件(self.filepath),用wb.Worksheets(‘AllCases')打開sheet頁'AllCases',注意Worksheets的W是大寫的,也記得加上s,用f.readlines()來讀取每一行,將每一行用for in 遍歷寫入一個(gè)表格,這里邊的Range(‘A1')表示單元格A1,加上.Value就是它的值。

with open(self.src, 'r') as f:
   wb = self.excel.Workbooks.Open(self.filepath)
   sheet_AllCases = wb.Worksheets('AllCases')
   i = 2
   for case in f.readlines():
     cel = 'K%d' % i
     sheet_AllCases.Range(cel).Value = case.strip()
     i = i + 1

強(qiáng)大的win32com.client

通過以下這種方式就可以調(diào)用VBA的函數(shù)模塊了,如果你要用word,更改成 ' Word.Applicaiton ' 即可。第一個(gè)是啟用excel,第二個(gè)用于調(diào)用一些VBA中固有的變量,比如調(diào)用某個(gè)屬性,直接在其前邊加上即可。

excel = win32com.client.Dispatch('Excel.Application')
win32c = win32com.client.constants

運(yùn)用這個(gè),我們就可以調(diào)用VBA的一些函數(shù)模塊,比如刪除行的功能,在openpyxl中,我沒有找到直接刪除行的功能,而win32com,可以采用如下方式進(jìn)行刪除行:

sheet_AllCases.Rows(i).Delete()

這里邊需要注意的是,VBA中Delete或者很多函數(shù)是不加括號調(diào)用的,我們在python中,需要添加括號才可以用。

以下是填充上一行的格式,就是我們常用的下拉復(fù)制:

rg = "A%s:J%s" % (i-1, i-1)
selection = sheet_AllCases.Range("A29000:J29000").Select
selection.AutoFill(Destination=sheet_AllCases.Range(rg), Type=xlFillDefault)

透視表的功能實(shí)現(xiàn):

 def write_ReportRaw(self):
   # open excel and active sheet
   wb = self.excel.Workbooks.Open(self.filepath)
   sheet_ReportRaw = wb.Worksheets('ReportRaw')

   # refresh Pivot table for All cases and Failed Cases
   sheet_ReportRaw.PivotTables("PivotTable3").PivotCache().Refresh()
   sheet_ReportRaw.PivotTables("PivotTable4").PivotCache().Refresh()

   wb.Save()

這些函數(shù),你無需上網(wǎng)去找,可以直接打開excel表格,在view下有一個(gè)Macros,采用Record Macros,然后手動(dòng)去刷新透視表,停止record,view macro就可以看到刷新透視表的代碼了,可以直接copy過來,將相應(yīng)的參數(shù)更改,同時(shí)要記得添加括號,上邊中,PivotCache()如果沒加括號,無法使用。

其他的功能,可以根據(jù)自己的需要進(jìn)行調(diào)用。

注意點(diǎn)

使用win32com.client可以讓你更加順利的處理各種excel或者word的復(fù)雜情況,相比于openpyxl, xlrd, xlwd功能會(huì)更加齊全。但使用過程中,也要注意一些點(diǎn):

  • 前邊說到的,要對函數(shù)加括號
  • python雖然并不是特別在意大小寫,但是使用win32com.client一定要注意大小寫,很多函數(shù)如果不區(qū)分大小寫,是無法調(diào)用的,比如打開excel表格的Open函數(shù),'O'必須大寫,還有wb.Save(),‘S'也必須大寫,而我們使用openpyxl使用小寫即可。
  • openpyxl在保存時(shí)用save(),很多原有的格式圖表是無法保留下來的,比如對excel進(jìn)行修改,里邊原有的透視表,用openpyxl的save()是無法保存的,但是使用win32com.client的wb.Save()卻是可以保存這些圖表的,這也是更加方便的地方。
  • 關(guān)于VBA函數(shù)模塊調(diào)用,直接采用錄制宏的方式獲取,無需去找文檔,這也是更加方便靈活的地方。

到此這篇關(guān)于Python如何操作office實(shí)現(xiàn)自動(dòng)化及win32com.client的運(yùn)用的文章就介紹到這了,更多相關(guān)Python操作office自動(dòng)化內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • PyQt5顯示GIF圖片的方法

    PyQt5顯示GIF圖片的方法

    今天小編就為大家分享一篇PyQt5顯示GIF圖片的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06
  • 關(guān)于Python3 lambda函數(shù)的深入淺出

    關(guān)于Python3 lambda函數(shù)的深入淺出

    今天小編就為大家分享一篇關(guān)于Python3 lambda函數(shù)的深入淺出,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • matplotlib設(shè)置顏色、標(biāo)記、線條,讓你的圖像更加豐富(推薦)

    matplotlib設(shè)置顏色、標(biāo)記、線條,讓你的圖像更加豐富(推薦)

    這篇文章主要介紹了matplotlib設(shè)置顏色、標(biāo)記、線條,讓你的圖像更加豐富,本文通過實(shí)例圖文相結(jié)合給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09
  • R語言繪制條形圖及分布密度圖代碼總結(jié)

    R語言繪制條形圖及分布密度圖代碼總結(jié)

    這篇文章主要為大家介紹了R語言條形圖及分布密度圖代碼總結(jié),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • Python中用Descriptor實(shí)現(xiàn)類級屬性(Property)詳解

    Python中用Descriptor實(shí)現(xiàn)類級屬性(Property)詳解

    這篇文章主要介紹了Python中用Descriptor實(shí)現(xiàn)類級屬性(Property)詳解,本文先是講解了decorator是什么,然后給出了通過Descriptor來做一個(gè)類級的Property實(shí)例,需要的朋友可以參考下
    2014-09-09
  • python pycharm最新版本激活碼(永久有效)附python安裝教程

    python pycharm最新版本激活碼(永久有效)附python安裝教程

    PyCharm是一個(gè)多功能的集成開發(fā)環(huán)境,只需要在pycharm中創(chuàng)建python file就運(yùn)行python,并且pycharm內(nèi)置完備的功能,這篇文章給大家介紹python pycharm激活碼最新版,需要的朋友跟隨小編一起看看吧
    2020-01-01
  • Python實(shí)現(xiàn)將多個(gè)空格換為一個(gè)空格.md的方法

    Python實(shí)現(xiàn)將多個(gè)空格換為一個(gè)空格.md的方法

    今天小編就為大家分享一篇Python實(shí)現(xiàn)將多個(gè)空格換為一個(gè)空格.md的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12
  • Python實(shí)現(xiàn)登錄接口的示例代碼

    Python實(shí)現(xiàn)登錄接口的示例代碼

    本篇文章主要介紹了Python實(shí)現(xiàn)登錄接口的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-07-07
  • 如何利用python查找電腦文件

    如何利用python查找電腦文件

    利用python查找電腦里的文件非常方便,首先是導(dǎo)入模塊os,然后利用os.listdir()打開目錄下的所有文件,files其實(shí)是一個(gè)列表。具體操作方法大家參考下本文
    2018-04-04
  • Python 窗體(tkinter)按鈕 位置實(shí)例

    Python 窗體(tkinter)按鈕 位置實(shí)例

    今天小編就為大家分享一篇Python 窗體(tkinter)按鈕 位置實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06

最新評論