xlwings excel(四)

前言

當年看《別怕,Excel VBA其實很簡單》相見恨晚,看了初版電子版以後,買了紙質版,而後將其送人。然後,發現出了第二版,買之收藏。以後,發現Python這一編程語言,簡直是逆天,業餘非程序員的福音。人生苦短,我用python。簡短几句代碼,實現好多本身不敢想的功能。
自學VBA發現對VBA和python,我有着這樣幾個見解:(只是針對自動化辦公)python

  • 非專業表哥,只是普通辦公,但願偶爾遇到點重複的工做能夠自動化一下。VBA對於我來講,要記得東西仍是太多了,語法上不簡潔。每寫一個功能,代碼太長了。
  • VBA雖然在不少程序都有接口,可是,應用範圍仍是略窄,對於通常用戶深刻學習後,可是,應用場景太少。有任務驅動,纔有動力去提升水平。
  • Python運行速度絕對不算快的,可是,絕對比在Excel中運行VBA的速度仍是要快不少
  • Python語言簡潔(python大法好),模塊豐富,有好多大神造好的輪子等着咱們去用。
  • Python應用範圍廣,既能幫我解決偶爾遇到的表格問題,也能和其餘各類軟件或者平臺聯接起來。

運用Python自定義宏(僅限Windows)

  1. 準備工做
  2. 安裝xlwings模塊

  • 其中,自定義模版能夠修更名稱,mymacro爲自定義宏的python文件,myfun爲自定義函數的python文件。
  • 設置Excel信任中心,信任對VBA工程對象模型的訪問 程序員

自定義宏編程

  1. 用記事本打開mymacro0,輸入下列語句:
import xlwings as xw @xw.sub def my_macro(): wb = xw.Book.caller() wb.sheets[0].range('A1').value = wb.name 

則宏名稱爲my_macro的宏就編寫好了,將工做簿的名稱輸入到A1單元格。自定義宏只須要前兩句不變,後面內容本身編寫,即自定義宏須要如下面的語句爲開頭編程語言

import xlwings as xw @xw.sub 

運行方式:先alt+F8運行ImportPythonUDFs內置宏,導入咱們的自定義宏和函數,導入後,再運行我定義的my_macro宏。函數

  1. 自定義函數
    準備工做是一致的,打開myfun0,寫入第一個自定義函數:
import xlwings as xw @xw.func def myfun(): wb = xw.Book.caller() return wb.name 

注意,開頭語句爲@xw.func而不是@xw.sub了,而後函數相對於宏,有返回值,因此用了return語句。自定義好函數以後,剛能夠像Excel自帶函數同樣的去使用了。如在A1單元格輸入」=myfun()",則會獲得工做簿的名稱。學習

結束

本文給出了xlwings模塊自定義宏和函數的模版,而後簡單介紹瞭如何去定義宏和函數。注意:spa

  • 一個python文件,只能定義一個宏或者函數,因此模版中已經默認分別給出了三個宏和函數文件,方便直接使用。
  • python文件的名稱和相對文件位置不能改變,Excel文件的文件位置不能改變,名稱能夠改變。如需修改,請參考xlwings官方文檔。
相關文章
相關標籤/搜索