之前被问到,Python 很强大,但是需要单独安装,而VBA是office自带的,
那么两者结合的话,如何用Python调用VBA呢?
代码如下(其中 A 是测试文件 宏的名字):
VBA代码:
Sub A()
MsgBox (123)
Range("B2").Value = 123
End Sub
Python代码
'''
@Author: Liang
@LastEditors: Liang
@Date: 2020-06-30 14:27:25
@LastEditTime: 2020-07-26 19:59:47
@Email: str-liang@outlook.com
@FilePath: /undefinedc:/Users/mayn/Downloads/test - 副本.py
@Description:
'''
import xlwings as xl
import time
app = xl.App(visible=True)
wb = app.books.open('C:/Users/mayn/Desktop/工作簿1.xlsm')
# Python调用VBA 的第一种方法
wb.macro('A')()
# Python调用VBA 的第二种方法
# macro_run = wb.macro('A')
# macro_run()
time.sleep(2)
app.quit()