Python量化VBA For Excelxlwings

插上翅膀,让Excel飞起来——xlwings(四)

2017-04-29  本文已影响4886人  早起收果子

前言

当年看《别怕,Excel VBA其实很简单》相见恨晚,看了第一版电子版之后,买了纸质版,然后将其送人。而后,发现出了第二版,买之收藏。之后,发现Python这一编程语言,简直是逆天,业余非程序员的福音。人生苦短,我用python。简短几句代码,实现好多自己不敢想的功能。
自学VBA发现对VBA和python,我有着这样几个看法:(只是针对自动化办公)

运用Python自定义宏(仅限Windows)

  1. 准备工作
  2. 安装xlwings模块
  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模块自定义宏和函数的模版,然后简单介绍了如何去定义宏和函数。注意:

上一篇下一篇

猜你喜欢

热点阅读