您当前的位置:首页 > 电脑百科 > 程序开发 > 语言 > Python

Python结合VBA进行数据处理与报表制作

时间:2019-09-10 11:51:38  来源:  作者:
Python结合VBA进行数据处理与报表制作

 

Python的好处是,可以把一系列的操作全部通过程序完成,步骤分解下来有这些:

1、通过爬虫获取数据(用selenium操作,当然这个是最愚蠢且效率最低的办法,最好还是直接后台数据库调取);

2、用VBA和PQ配合完成数据的刷新和报表的制作;

3、用SMTP完成邮件发送(但是现在有bug,可能是某些二流服务器的问题,附件总是收不到或者是变成.dat文件,比如189邮箱。。。比如outlook。。。);

4、用itchat完成微信内的表格和文字发送。

上述四个步骤中,目前已经实现了2、3、4(3和4的代码可以参看我之前的文章)

其实用VBA就能解决报表的制作和邮件发送了,但是1和4是肯定没办法完成的,而Python至少还有可能性!

使用的VBA代码和Python代码如下(主要思路就是用宏操控PQ,用Python操控宏):

Python代码:

  •  
import win32com.client
#运行宏
def useVBA(file_path, VBA):
 xlApp = win32com.client.DispatchEx("Excel.Application")
 xlApp.Visible = True
 xlApp.DisplayAlerts = 0
 xlBook = xlApp.Workbooks.Open(file_path,False)
 xlBook.Application.Run(VBA) #宏
 xlBook.Close(True)
 xlApp.quit()
file_path1=r"C:UsersAdministratorDesktop报表日报!源数据(每日刷新).xlsm"
file_path2=r"C:UsersAdministratorDesktop报表日报日报模板(会用宏的可以用用).xlsm"
useVBA(file_path1, '数据刷新宏')
useVBA(file_path2, '日报宏')

数据刷新宏代码:

  •  
Sub 数据刷新宏()
 ActiveWorkbook.RefreshAll
End Sub

 

日报宏代码:

  •  
Sub 日报宏()
'获得昨天的标准日期(1018这种格式)
yesterday = DateAdd("d", -1, Now)
yesterday_format = Format(yesterday, "mmdd") & ".xlsx"
Path = Application.ThisWorkbook.Path
'增加一段代码,强制必须刷新
ActiveWorkbook.UpdateLink Name:= _
 Path & "!源数据(每日刷新).xlsm", Type:=xlExcelLinks
Sheets("门店维度").Select
 Cells.Select
 Range("A2").Activate
 ActiveWorkbook.BreakLink Name:= _
 Path & "!源数据(每日刷新).xlsm", Type:=xlExcelLinks
 Selection.Replace What:="#N/A", Replacement:="0", LookAt:=xlPart, _
 SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _
 ReplaceFormat:=False
 Sheets("门店通报").Select
 Range("A1:K1").Select
 Selection.Copy
 Range("A2:K2").Select
 Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
 :=False, Transpose:=False
 Application.CutCopyMode = False
 ActiveWorkbook.SaveAs Filename:= _
 Path & "【基础经营-实体1】:“乘风破浪”百日冲刺报表" & yesterday_format, _
 FileFormat:=xlOpenXMLWorkbook, CreateBackup:=False
End Sub

 

其中的VBA代码需要根据不同的情况和需求更改,但是Python通过调用VBA可以实现自动化的操作并实现定时的执行脚本

来源网络,侵权联系删除



Tags:Python VBA   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
用Python的好处是,可以把一系列的操作全部通过程序完成,步骤分解下来有这些:1、通过爬虫获取数据(用selenium操作,当然这个是最愚蠢且效率最低的办法,最好还是直接后台数据库调取...【详细内容】
2019-09-10  Tags: Python VBA  点击:(202)  评论:(0)  加入收藏
▌简易百科推荐
大家好,我是菜鸟哥,今天跟大家一起聊一下Python4的话题! 从2020年的1月1号开始,Python官方正式的停止了对于Python2的维护。Python也正式的进入了Python3的时代。而随着时间的...【详细内容】
2021-12-28  菜鸟学python    Tags:Python4   点击:(1)  评论:(0)  加入收藏
学习Python的初衷是因为它的实践的便捷性,几乎计算机上能完成的各种操作都能在Python上找到解决途径。平时工作需要在线学习。而在线学习的复杂性经常让人抓狂。费时费力且效...【详细内容】
2021-12-28  风度翩翩的Python    Tags:Python   点击:(1)  评论:(0)  加入收藏
Python 是一个很棒的语言。它是世界上发展最快的编程语言之一。它一次又一次地证明了在开发人员职位中和跨行业的数据科学职位中的实用性。整个 Python 及其库的生态系统使...【详细内容】
2021-12-27  IT资料库    Tags:Python 库   点击:(2)  评论:(0)  加入收藏
菜单驱动程序简介菜单驱动程序是通过显示选项列表从用户那里获取输入并允许用户从选项列表中选择输入的程序。菜单驱动程序的一个简单示例是 ATM(自动取款机)。在交易的情况下...【详细内容】
2021-12-27  子冉爱python    Tags:Python   点击:(4)  评论:(0)  加入收藏
有不少同学学完Python后仍然很难将其灵活运用。我整理15个Python入门的小程序。在实践中应用Python会有事半功倍的效果。01 实现二元二次函数实现数学里的二元二次函数:f(x,...【详细内容】
2021-12-22  程序汪小成    Tags:Python入门   点击:(32)  评论:(0)  加入收藏
Verilog是由一个个module组成的,下面是其中一个module在网表中的样子,我只需要提取module名字、实例化关系。module rst_filter ( ...); 端口声明... wire定义......【详细内容】
2021-12-22  编程啊青    Tags:Verilog   点击:(9)  评论:(0)  加入收藏
运行环境 如何从 MP4 视频中提取帧 将帧变成 GIF 创建 MP4 到 GIF GUI ...【详细内容】
2021-12-22  修道猿    Tags:Python   点击:(6)  评论:(0)  加入收藏
面向对象:Object Oriented Programming,简称OOP,即面向对象程序设计。类(Class)和对象(Object)类是用来描述具有相同属性和方法对象的集合。对象是类的具体实例。比如,学生都有...【详细内容】
2021-12-22  我头秃了    Tags:python   点击:(9)  评论:(0)  加入收藏
所谓内置函数,就是Python提供的, 可以直接拿来直接用的函数,比如大家熟悉的print,range、input等,也有不是很熟,但是很重要的,如enumerate、zip、join等,Python内置的这些函数非常...【详细内容】
2021-12-21  程序员小新ds    Tags:python初   点击:(5)  评论:(0)  加入收藏
Hi,大家好。我们在接口自动化测试项目中,有时候需要一些加密。今天给大伙介绍Python实现各种 加密 ,接口加解密再也不愁。目录一、项目加解密需求分析六、Python加密库PyCrypto...【详细内容】
2021-12-21  Python可乐    Tags:Python   点击:(8)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条