系列文章 "替代Excel Vba"系列(一):用Python的pandas快速汇总 "Python替代Excel Vba"系列(二):pandas分组统计与操作Excel "Python替代 Excel Vba"系列(三):pandas处理不规范数据 Python替代Excel Vba"系列(四):课程表分析与动态可视化图表 前言 有小伙伴向我反映到,本系列前面的章节主要还是在讲 pandas 本文要点: 使用 xlwings 注册 Python 方法到 Vba 模块 Vba 调用 Python 方法,输出结果到 Excel 注意:虽然本文是"Python替代Excel Vba"系列,但希望各位读者明白 其他就不细说了,会 vba 的小伙伴应该一看就懂。 ---- ---- 最后 你发现这样做的一个好处是,无需重复启动 Python ,因为每次启动 Python 都需要不少时间(大概2、3秒的样子)。 而本文的做法,可以让其 Python 进程一直存在。 总结 使用 xlwings 可以让 Vba 调用 Python 。 把复杂的汇总处理流程让给 Python 处理。
1、什么是VBA操作VBA: 前面的VBA意思是指VBA程序,后面的VBA是指VBA工程对象(代码和组织代码的模块、类等)。 也就是一段运行过程中的VBA程序,可以去操作VBA工程对象。 能被操作的东西显然就是一种对象,首先如果要使用VBA去操作VBA工程对象,先按如下设置: ? 勾选信任对VBA工程对象模型的访问,这时候就可以去使用VBA工程对象了。 在使用VBA编辑器的时候,有一个叫做工程资源管理器的窗口: ? 3、输出VBA工程对象名称: 简单使用一下这个VBA工程对象,和其他VBA库对象用法都差不多,要输出打开的这些VBA工程名称,非常简单,只要循环然后输出它的Name属性: Sub TestVBProject 工程对象和前面说过的Range、Worksheet等对象都一样,都是在VBA里做好了的东西,作为使用者只需要知道如何去使用对象就可以,无非还是定义对象、使用对象的方法、属性等。
个人网站、项目部署、开发环境、游戏服务器、图床、渲染训练等免费搭建教程,多款云服务器20元起。
前言 上一节我们讨论了 Python 在数据处理上的优势,前后台大概收到的有用评论如下: "了解下 power query,可以很简单解决" "你文中说到vba也可以做到在固定代码中插入逻辑,具体如何做到 但是今天我要首先替 vba 说一句公道话,难道Excel数据处理任务的vba代码,真的不可能做到像 pandas 一样简洁直白吗?某些场景下,绝对可以! 代码多余表达要接近于 python 代码 就算换另一份数据,只需要修改关键表达即可使用(比如按某字段分组,只需要修改字段名字即可),无须大范围修改代码。 为什么python比vba更适合自动化处理Excel数据? 但是,vba 真的就不能做到"封装固定逻辑的同时,给予使用者放入自定义逻辑" 吗? 这就是 vba 中实现插入逻辑的实现方式,非常简单。
有时候,我们可能想要从Python运行Excel VBA宏,特别是当想要运行已有的Excel宏时,这很有用——甚至可以在不打开Excel文件的情况下执行这些VBA宏。 注意,要安装py32win库,在命令提示符下键入以下命令: pip install pywin32 然而,要在Python中导入该库,则其名字成为win32com.client: import win32com.client Excel VBA宏 下面是一个非常简单的Excel VBA宏,它接受一个参数,在工作表Sheet1的单元格B2中输入一条问候语。 当然,可以创建任何宏并使用Python运行它。 End Sub 从Python中运行VBA宏 现在,将编写Python代码,从导入win32com.client开始,并实例化一个“xl”对象来表示Microsoft Excel应用程序。
Dim FileName As String FileName = Application.GetOpenFilename("Excel文件(.xls & .xla),.xls;.xla", , "VBA Then CMGs = i If GetData = "[Host" Then DPBo = i - 2: Exit For Next If CMGs = 0 Then MsgBox "请先对VBA
背景: 已有一个Python脚本实现了部分功能,想使用VBA直接调用Python脚本 Python脚本如下: import time def hello(name): return "Hello, " 使得用户可以看到运行结果 time.sleep(150); 方法如下: Sub test() Call Shell("C:\Python27 \Python.exe C:\Users\Hongxing\Desktop\py2exe\Hello.py", vbNormalFocus) End Sub
Sub test() Call Shell("C:\Python27 \Python.exe C:\Users\Hongxing\Desktop\py2exe\Hello.py", vbNormalFocus) End Sub
现在的情况是,除了Python之外,很多金融机构,像投行(这个会多一些)、对冲基金等金融机构现在已经很少使用VBA了。 下面的图表说明了这个问题。 我们先给答案: VBA在未来10年仍然会被广泛使用 VBA虽然老,但不会完全消失 它还可以学,还可以学很久 根据微软社区的一个投票可以看出,微软正考虑添加Python为官方的一种Excel脚本语言,如果获得批准 ,Excel用户将能够像目前使用VBA脚本一样,使用Python脚本与Excel文档、数据以及一些Excel核心函数进行交互。 甚至当时有传言微软将在最后一个单机版本2019版中彻底放弃VBA,全面支持Python…… 后来呢,2020年了,你懂得。 ? 在计算机专业的眼里VBA一直都没地位,许多高级程序员瞧不上VBA,因为程序员的鄙视链是: 汇编 > C > C++ > Python > Java及C#及PHP(这三者相互撕)> VB > HTML 在这长长的鄙视链中甚至都没有
有了前面VBA工程对象的基础,要操作代码就容易了,只要找到对象对应的属性、方法就可以。 在Excel中,VBA代码存放的地方是模块、类模块、窗体,这些在VBA工程模型中叫做VBComponents。 CodeModule就是保存VBA代码的窗口,要读取CodeModule的代码,需要指定对应的起始行和终止行。
对于会使用VBA的人来说,一个一个的手动去复制肯定是受不了的,那么来看看使用VBA如何快速处理这种情况: ? Then Exit Sub If selectRng.Cells.Count = 1 Then rngout.Value = FGetnum(VBA.CStr UBound(arr, 1) For j = 1 To UBound(arr, 2) arr(i, j) = FGetnum(VBA.CStr (str) '找到第一个是数字的位置 If VBA.IsNumeric(VBA.Mid$(str, i, 1)) Then '使用Val函数转换 FGetnum = VBA.Val(VBA.Mid$(str, i)) Exit Function End If Next End
最近熟悉了手头上的工作之后,开始觉得很多动作其实是没有必要的,加上慢慢时间多了起来,于是开始想办法进一步自动化目前的工作流程.我目前的工作流程是这样的:[Python自动下载数据]→[VBA工具汇总并插入数据库 ]→[清除下载文件] 环节比较多,任何一个地方出错了都没办法继续下去.例如上次的文件没有清除,为了防止重复合并我设置了一个文件数限制的VBA代码,但是这样又会浪费时间来检查文件.python下载的时候也经常会下载一些空文件 所以我在寻找python来处理和检查Excel的方法,如果可以,最好从下载到导入数据库全部都使用python监控并完成. Python+Selenium模拟操作下载数据 这里见之前的文章 安利一个超好用的网页自动操作工具 Step 2 使用Python操作Excel 只需要最少4行代码,就可以打开工作簿并运行里面的VBA ,简单快速的结合了Python与VBA 我提前写好的VBA代码是这样的,就是一个显示当前时间的VBA 运行结果如下所示 使用Python的方法是:双击文件 Step 3 删除下载文件夹下的所有文件
今天来讲讲 Python 语言中一个非常重要的语法概念:函数 数学上的函数,是指给定一个输入,就会有唯一输出的一种对应关系。编程语言里的函数跟这个意思差不多,但也有不同。 我们在课程的一开始就已经用到过python里内建的函数,比如 print、input 和 range。 以 range(1,10)为例,range是这个函数的名称,后面括号里的1和10是range需要的参数。它有返回结果,就是一个从1到9的序列。 python里的关键字叫 def(define的缩写),格式如下面这个例子: def sayHello(): print('hello world!') 以上就是对 Python 函数的简单介绍。关于函数的参数、返回值,以及更复杂的变量作用域等概念,可以在公众号 Crossin的编程教室 的历史文章里搜索相关关键字查找。
VBA是什么 自己的理解:VBA就是一种语言,你用符合语言规则的语句写出来后,VBA解析器能够完全认识的话,它就能按照规则进行执行。和我们日常的语言中文、英文等是一个道理。 (官方说明请baidu) 如何开始 VBA不能单独使用,必须和某一种文档在一起。我们以Excel为例,首先为了以后方便使用,需要进行一些简单设置: ? 把菜单开发工具显示出来方便以后打开VBA编辑器(点“Visual Basic”打开的那个界面)、设置宏安全性是为了能够打开文件就执行程序(这一步设置后,一定要关闭所有的Excel)、VBA编辑里的设置我的已经设置好了 开始录制后,VBA编辑器里就多了1个叫做“模块1”的东西,这个东西就是写代码的地方。 图中可以看出,我的每一步都被记录了,你可以自己多试试,至于出来的是什么可以暂不去管。 小结 这里只是非常初步的了解了一下VBA,下一次自己动手写一个。
UTF-8" '设定编码 .Position = 2 ReadUTF = .ReadText '读取文本 .Close '关闭 End With End Function 'VBA 调用过程并把返回值放入r End Sub '结束过程 Function 函数名(a, Optional ByVal b) 'Function表示函数,在单元格中也可以使用,宏列表看不到,可以使宏列表简洁 'VBA
标签:VBA,Python,微积分 这段时间,一直利用晚上的空余时间在学习微积分,想将研究微积分作为自己的一项业余爱好,就好比研究Excel一样,奇怪吧! 下面我们分别使用Python和VBA来计算,基本算法就是利用定积分的定义。 (注:有兴趣的朋友可以查阅相关资料,了解定积分的定义,从而更好地理解程序) Python 编写的程序代码如下: from numpy import * a,b = 0, 1 def f(x): 图1 VBA 下面我们看看VBA代码及其结果。
如果你收到过一些这样的Excel文件,文件里有VBA代码,实现了很好的功能,可是作者却对VBA工程进行了加密,你可能会非常希望查看到里面的VBA代码。 会想到的最直接的办法当然就是要到密码,可这个一般做不到,这个时候有什么办法能够查看VBA代码呢? 前面介绍的提取模块代码可以做到,这里再介绍一种直接清除密码的功能。 所以,知道了这样能够清除密码,我们要做的只是改写一个复合文档的数据流就可以了: '清除vba工程密码 '清除CMG=" | DPB=" | GC=" '清除VBA工程密码 'Return 返回出错信息 (strSrc, arr(i)) If index Then flag = True index2 = VBA.InStr(index, strSrc, vbNewLine) If index2 Then strtmp = VBA.Mid$(strSrc, index, index2
目录 1.python数组下标 2.b=a[i:j] 3.b=a[i:j:k] ---- 1.python数组下标 python下标有两套,一套是正的,一套是负的, a=’python’的下表如下 p 默认为0,即 a[:3]相当于 a[0:3] 当j缺省时,默认为len(alist), 即a[1:]相当于a[1:len(alist)] 当i,j都缺省时,a[:] 就相当于完整复制一份a 例如: a=’python
日常工作中经常需要对一系列的表进行合并,或者对一份数据按照某个分类进行拆分,今天我们介绍Python和VBA两种实现方案供大家参考~ 1.Excel表格合并 1.1.Python实现表格合并 1.2.VBA实现表格合并 2.Excel表格拆分 2.1.Python实现表格拆分 2.2.VBA实现表格拆分 1.Excel表格合并 我们在日常工作中经常会导出一些数据,但是这些数据较大可能是按照某个分类形成的单独表格 1.1.Python实现表格合并 Python实现表格合并的本质是 遍历全部表格数据,然后采用concat方法进行数据合并Pandas学习笔记02-数据合并。 同样在这里,我们分别介绍Python实现和VBA实现两种方案! )) '如果在字典里 If D.exists(TempStr) Then '将数据放到对应的页里 Set Sht = Worksheets
柯里化 指的是将原来接受两个参数的函数变成新的接受一个参数的函数的过程。 新的函数返回一个以原有第二个参数为参数的函数 z = f(x, y) 转换成 z = f(x)(y)的形式 举例: """ 将加法函数柯里化 """ def add(x, y): return return x + y return _add foo = add(4) print(foo(5)) print(add(4)(5)) 通过嵌套函数就可以把函数转换成柯里化函数
Serverless HTTP 基于腾讯云 API 网关平台,为互联网业务提供 0 配置、高可用、弹性扩展的对外 RESTful API 能力,支持 swagger/ openAPI 等协议。便于客户快速上线业务逻辑,通过规范的 API 支持内外系统的集成和连接。
扫码关注腾讯云开发者
领取腾讯云代金券