插上翅膀,讓Excel飛起來——xlwings(四)


前言

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

  • 非專業表哥,只是普通辦公,希望偶爾遇到點重復的工作可以自動化一下。VBA對於我來說,要記得東西還是太多了,語法上不簡潔。每寫一個功能,代碼太長了。
  • VBA雖然在很多程序都有接口,但是,應用范圍還是略窄,對於一般用戶深入學習后,但是,應用場景太少。有任務驅動,才有動力去提高水平。
  • Python運行速度絕對不算快的,但是,絕對比在Excel中運行VBA的速度還是要快很多
  • Python語言簡潔(python大法好),模塊豐富,有好多大神造好的輪子等着我們去用。
  • Python應用范圍廣,既能幫我解決偶爾遇到的表格問題,也能和其他各種軟件或者平台聯接起來。

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

  1. 准備工作
    1. 安裝xlwings模塊
    2. 下載模版文件,百度網盤鏈接:xlwings自定義宏和函數模版

      文件列表

      其中,自定義模版可以修改名稱,mymacro為自定義宏的python文件,myfun為自定義函數的python文件。
    3. 設置Excel信任中心,信任對VBA工程對象模型的訪問

      信任中心設置
  2. 自定義宏
    用記事本打開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宏。

    執行
  3. 自定義函數
    准備工作是一致的,打開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模塊自定義宏和函數的模版,然后簡單介紹了如何去定義宏和函數。注意:

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


作者:LuckyFrog
鏈接:http://www.jianshu.com/p/7d6f53e3e6e9
來源:簡書
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM