python调用vba脚本_如何使用xlwings v0.10调用Excel VBA脚本

本文探讨了作者在从xlwings v0.9.x迁移到v0.10.0版本时,遇到的问题:如何在Python中通过xlwings调用VBA宏进行复杂操作。作者分享了尝试过的代码片段,并寻求如何在新版本中正确调用宏以实现格式化和公式添加。
摘要由CSDN通过智能技术生成

我曾经使用这个问题中的信息来运行一个VBA脚本,它在运行我的python代码后执行一些基本的格式化 .

具体来说我使用了第一次更新 .

from xlwings import Workbook, Application

wb = Workbook(...)

Application(wb).xl_app.Run("your_macro")

现在我正在使用xlwings的v0.10.0,这段代码不再有效 .

当我尝试v0.10.0的建议新代码时:

wb.app.macro('your_macro')

Python返回一个对象:

我的宏不在Excel中运行 .

文档(http://docs.xlwings.org/en/stable/api.html#xlwings.App.macro)有一个自定义函数的例子,但我有一个脚本可以在Excel中执行多项操作(格式化我从python输出的数据,在工作表中添加一些公式等),我想运行它 .

我确定我在这里缺少一些基本的东西 .

Update 根据Felix Zumstein的建议,我试过:

import xlwings as xw

xlfile = 'model.xlsm'

wb = xw.Book(xlfile)

wb.macro('your_macro')

这返回与wb.app.macro('your_macro')相同的内容:

并且没有在Excel中运行VBA脚本 .

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值