Python 的库总是异常丰富,比如 Python 操作 Excel ,根据 详解Python操作Excel文件 这篇文章的介绍,竟然达到了 9 种之多,文章的列举还不一定是穷举式的。这么多库,也没必要都去试用,根据自己的需求,选择一种两种熟练掌握即可。

今天要介绍的是一个有点特别的库 xlwsings,允许你在 VBA 中调用 Python 代码,从而大大简化很多事务性工作的处理。并且使用简单方便,值得一试。

下载和安装

xlwings 已经支持 pip 安装了,在命令窗口输入下面的命令进行自动下载和安装:

pip install xlwings

目前 xlwings 的版本为 0.15.10,所以估计后续存在较大变化的可能。

Python 代码操作 Excel

打开命令行窗口,在命令行输入如下的命令:

D:\xlwings-test>xlwings quickstart xlwingshello

xlwings 在当前目录下创建一个名为 xlwingshello 的文件夹,同时在 xlwingshello 目录下新建两个文件:

xlwingshello \xlwingshello.pyxlwingshello.xlsm

通过 quickstart 命令创建的这两个文件含有一些初始配置和代码,省去了我们手工配置的麻烦。xlwingshello.py 中的代码,提供了如何从 Excel VBA 中进行调用 Python 模块的代码的简单示例。

打开 xlwingshello.py 文件,输入如下代码:

import xlwings as xw def write_hello():    wb = xw.Book()    # create a new workbook    sht = wb.sheets[0] # Open worksheet     sht.range("A1").value = "Hello, xlwings!"  # write hello in cell A1write_hello()

三行代码就实现了在 Python 中操作 Excel,确实方便,代码也很直观。

VBA 调用 Python 代码

安装 xlwings 之后,xlwings 库在我们的电脑中放置了一个名为 xlwings.xlam 的 Excel 加载宏文件,这个文件的位置在Python 安装文件夹下面的 site-packages 文件夹中。在我的我电脑上加载宏 (Excel Addin) 文件位置为:


什么是 Excel 加载宏文件呢?我之前写过一篇博客:如何在 VBA 中运行 Excel Add-in 中的代码,文中有解释,也说明了使用方法,请自行参考。

打开 xlwingshello.xlam 文件,切换到【开发工具】选项卡,如果没有出现【开发工具】选项卡,请打开自定义功能区对话框,将选项卡 “开发工具”勾上,默认 Excel 是不显示“开发工具”选项卡的:


切换到【开发工具】,点击【Visual Basic】,进入 Visual Basic Editor (VBE) 环境,进入 VBE 环境的快捷键是 Alt + F11:


我们看到,在 VBA 中调用 Python 代码,需要 xlwings.xlam 加载宏提供支持,但实际上,此时直接运行 Module 1 中自动生成的代码会提示错误,因为并没有成功加载 xlwings.xlam 加载宏,出现引用丢失,原因是 xlwingshello.xlsm 文件中加载宏的位置是写死的,所以不可能适用每一台 PC,我们需要用手工方式来加载。加载方法:在 VBE 环境中通过菜单 【工具】-【引用】打开“引用”对话框,下图显示了“引用”丢失。


怎么解决呢?可以把刚才安装路径下的 xlwings.xlam 文件拷贝到工程所在目录,也可以拷贝到 Excel 默认的加载项位置。这个位置使用下面的方法获得:调出 VBE 环境的立即窗口,在立即窗口中输入:

debug.Print Application.UserLibraryPath

得到的位置就是默认加载项位置。

将文件拷到到 Addins 文件夹,然后回到 Excel 界面,切换到【开发工具】功能区,点击【Excel 加载项】:


默认位置的加载项自动出现在列表中,选中 xlwings ,点击确定按钮。


再进入 VBE 环境,打开库引用对话框,勾上 xlwings:


然后运行 xlwingshello.xlam 中的示例代码,此时能成功运行。

Sub SampleCall()mymodule = Left(ThisWorkbook.Name, (InStrRev(ThisWorkbook.Name, ".", -1, vbTextCompare) - 1))RunPython ("import " & mymodule & ";" & mymodule & ".hello_xlwings()")
End Sub

这段代码导入文件夹下同名的 Python 模块,调用模块中 hello_xlwings()· 方法:

import xlwingshello
xlwingshello.hello_xlwings()

我们再看看 hello_xlwings() 函数:

def hello_xlwings():wb = xw.Book.caller()wb.sheets[0].range("A1").value = "Hello xlwings!"

关于 xlwings.xlam 加载宏,其实 xlwings 还提供了一种命令行安装的方法,可以在 pip install xlwings 命令之后,在命令行窗口输入下面的命令安装:

xlwings addin install

addin install 命令在电脑上只需要运行一次,xlwings 将 xlwings.xlam 文件拷贝到 Excel 启动时自动加载的文件夹 (XLSTART),这样每次启动 Excel 就会自动加载这个加载宏。个人觉得不如放在 Addins 文件夹灵活。在 VBE 的立即窗口,通过下面的命令:

? application.StartupPath

获取 xlstart 文件夹位置。

Excel uses the xlstart folder to hand a number of its features. The first time most users find out about the xlstart folder is when their personal.xls file is saved there after recording their first macro. Excel uses the personal.xls file to store macros that users want to access globally in all Excel files.
Excel opens all files in the xlstart folder when it starts up. If you want a particular file to open each day, for example, if you use a spreadsheet based timesheet, then you can save the file in the xlstart folder.
from: https://accessanalytic.com.au/xlstart-folder/

从调用者 (caller()) 得到 workbook,然后将 “Hello, xlwings!” 写入到 A1 单元格。

仿照这个调用模式,我们在 xlwingshello.py 中新增下面的代码:

import xlwings as xw
import pandas as pd
from sqlalchemy import create_enginedef upload_employees():url = "mysql+pymysql://root:pwd@localhost:3306/stonetest?charset=utf8"engine = create_engine(url)emp_data = pd.read_sql("select * from emp_master", engine)wb = xw.Book.caller()wb.sheets[0].range("A2").options(index=True).value = emp_data

xlwings 支持 pandas DataFrame,这就太方便了。打开 xlwingshello.xlsm,新增一个 subroutine 如下:

Public Sub UploadEmployee()mymodule = "xlwingshello"RunPython ("import " & mymodule & ";" & mymodule & ".upload_employees()")
End Sub

在这个 Excel VBA 的模块中,VBA 调用 Python 模块中的 upload_employees(),将 emp_master 数据导入到工作表中。

参考

  • Interactive Data Analysis with Python and Excel
  • xlwings quick start

xlwings : 从此可以 VBA 调用 Python 代码啦相关推荐

  1. vba调用python代码_Python替代Excel Vba系列(终):vba中调用Python

    点击上方"数据大宇宙",设为星标,干货资料,第一时间送到! 系列文章 前言 有小伙伴向我反映到,本系列前面的章节主要还是在讲 pandas ,几乎与 xlwings 没有啥关系. ...

  2. Python操作Excel的Xlwings教程(八)——Excel使用VBA调用Python

    这次推文的主题,在Xlwings中使用VBA的宏来进行Excel的操作. 知识准备 在Xlwings的官方文档中,我寻找到了一个关于Python API的东西.传送门如下: https://docs. ...

  3. vba python 结合_xlwings利用VBA调用python

    安装配置完成后(与自定义函数UDFs的配置是一致的,加入xlwings加载项,alt+F11中引用xlwings等等常规操作后),通过 "RunPython"调用python代码. ...

  4. c调用python脚本如何获取结果_使用C++调用Python代码的方法详解

    一.配置python环境问题 1.首先安装Python(版本无所谓),安装的时候选的添加python路径到环境变量中 安装之后的文件夹如下所示: 2.在VS中配置环境和库 右击项目->属性-&g ...

  5. java调用python代码

    同样的我们需要安装jython,具体的步骤如下: 1. 去 http://sourceforge.net/projects/jython/ 下载最新的jython相关的jar包. 2. 下载下来的ja ...

  6. java代码调用python_java调用python代码-阿里云开发者社区

    同样的我们需要安装jython,具体的步骤如下: 2. 下载下来的jar包其实既是使用的时候需要引入的jar包,也是安装就jython的jar包.具体安装细节参照:https://wiki.pytho ...

  7. C++ 调用 Python 代码 - Clion QT混合编程 ,各取长处。

    Qt 自带编辑器 调用Python  Clion 编辑器    调用Python 前言:python 无所不能.代码简洁,易于维护,开发效率很快.就是运行速度太慢. C++速度快,但是开发繁琐,没有p ...

  8. Qt Creator与Qt+VS2015调用Python代码的实现

    下面来介绍分别用Qt Creator与Qt+VS2015调用Python代码,首先电脑中要安装Python IDE与Qt.我电脑中安装的是Python37,VS2015+Qt5.8.Qt Creato ...

  9. JavaScript调用Python代码

    JavaScript 可以使用 Node.js 的 child_process 模块来调用 Python 代码. 例如,你可以使用 child_process.spawn 方法来调用 Python 脚 ...

最新文章

  1. boost::mpl模块实现multiset相关的测试程序
  2. Postgres主进程文件—postmaster.pid
  3. 解决在servlet中输出html的中文输出为问号的问题
  4. 微信公众号是html页面吗,微信公众号网页开发
  5. 华表 java_华表基础(转)
  6. java为纯图PDF添加图片水印
  7. vue嵌入app中——首次加载慢的动画
  8. sqlserver with ties
  9. 抖音自媒体火爆短视频如何造?
  10. centos6.8服务器中了挖矿程序病毒的解决方法
  11. 7 SY Vue 原理 副本 页面编辑错误
  12. MATLAB余弦相似性学习
  13. Linux查看内存型号,插槽使用情况,内存频率,内存制造商等信息
  14. 向日葵在mac不能以服务器运行吗,使用向日葵软件实现mac远程桌面连接windows的步骤...
  15. idea 自动导包 设置 快捷键
  16. 前端最常见的移动App分类介绍及优缺点
  17. 世界电信和信息社会日 | TcaplusDB君节日介绍
  18. 三人表决器逻辑表达式与非_STEP7编程语言学习之STL语言的学习——一.位逻辑指令的学习...
  19. 图像处理中的Tone Mapping初步学习
  20. MySQL Connector/J 8.0

热门文章

  1. 判断闰年?提示:year能被4整除但是不能被100整除 或者 year能被400整除, 那么就是闰年;
  2. 数据结构与算法单排日记-2020/3/6-链表之双链表
  3. XSS漏洞总结和漏洞复现
  4. 使用Python程序批量发送QQ邮件
  5. PyQt5 创建系统托盘
  6. 每日一练 JS30挑战 HTML5播放器
  7. 《见识》最后一章:巴菲特午餐:人生的智慧
  8. yolov5 CUDA out of memory
  9. 灵动ICPC冬令营基础-2
  10. 谷粒学院项目讲师管理(二)