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

前言

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

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

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

  1. 準(zhǔn)備工作
  2. 安裝xlwings模塊
  • 下載模版文件,百度網(wǎng)盤鏈接:xlwings自定義宏和函數(shù)模版
    文件列表

    其中,自定義模版可以修改名稱,mymacro為自定義宏的python文件,myfun為自定義函數(shù)的python文件。
  • 設(shè)置Excel信任中心,信任對(duì)VBA工程對(duì)象模型的訪問


    信任中心設(shè)置
  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單元格。自定義宏只需要前兩句不變,后面內(nèi)容自己編寫,即自定義宏需要以下面的語句為開頭

import xlwings as xw
@xw.sub

運(yùn)行方式:先alt+F8運(yùn)行ImportPythonUDFs內(nèi)置宏,導(dǎo)入我們的自定義宏和函數(shù),導(dǎo)入后,再運(yùn)行我定義的my_macro宏。


執(zhí)行
  1. 自定義函數(shù)
    準(zhǔn)備工作是一致的,打開myfun0,寫入第一個(gè)自定義函數(shù):
import xlwings as xw
@xw.func
def myfun():
    wb = xw.Book.caller()
    return wb.name

注意,開頭語句為@xw.func而不是@xw.sub了,然后函數(shù)相對(duì)于宏,有返回值,所以用了return語句。自定義好函數(shù)之后,剛可以像Excel自帶函數(shù)一樣的去使用了。如在A1單元格輸入”=myfun()",則會(huì)得到工作簿的名稱。

結(jié)束

本文給出了xlwings模塊自定義宏和函數(shù)的模版,然后簡單介紹了如何去定義宏和函數(shù)。注意:

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 自從2014年開通[完美Excel]微信公眾號(hào)以來,堅(jiān)持分享已經(jīng)學(xué)習(xí)到的Excel和VBA知識(shí)和心得,目前已分享文...
    完美Excel閱讀 8,462評(píng)論 6 69
  • 1.1 VBA是什么 直到90年代早期,使應(yīng)用程序自動(dòng)化還是充滿挑戰(zhàn)性的領(lǐng)域.對(duì)每個(gè)需要自動(dòng)化的應(yīng)用程序,人們不得...
    浮浮塵塵閱讀 22,159評(píng)論 6 49
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,351評(píng)論 25 708
  • 要你命1000:數(shù)據(jù)管理 ////////////////////////////////////////////...
    ZZS_簡閱讀 1,587評(píng)論 0 5
  • 看這部電影時(shí)候內(nèi)心忽現(xiàn)那句“寵辱不驚,看庭前花開花落;去留無意,望天上云卷云舒?!彪娪笆冀K都讓我沉靜在優(yōu)美的旋律和...
    南南南南南南南南南南方閱讀 1,709評(píng)論 5 13

友情鏈接更多精彩內(nèi)容