
文章插图
用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, '日报宏')数据刷新宏代码:
【Python结合VBA进行数据处理与报表制作】Sub 数据刷新宏() ActiveWorkbook.RefreshAllEnd Sub
日报宏代码:
Sub 日报宏()'获得昨天的标准日期(1018这种格式)yesterday = DateAdd("d", -1, Now)yesterday_format = Format(yesterday, "mmdd") & ".xlsx"Path = Application.ThisWorkbook.Path'增加一段代码 , 强制必须刷新ActiveWorkbook.UpdateLink Name:= _ Path & "!源数据(每日刷新).xlsm", Type:=xlExcelLinksSheets("门店维度").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:=FalseEnd Sub
其中的VBA代码需要根据不同的情况和需求更改 , 但是Python通过调用VBA可以实现自动化的操作并实现定时的执行脚本
来源网络 , 侵权联系删除
推荐阅读
-
宝马5系|新宝马5系VS新奔驰E级,中改之后,谁的表现厚道
-
-
突发 | 一辆特斯拉Model S在美自燃,车主:电池爆炸了
-
名咖聊体育|新发现的“超地球”系外行星提供了有关外星世界大气的线索
-
草莓 学会了这道草莓珍珠,夏天最受宠的珍珠奶茶,在家也能做
-
拉斐尔·瓦拉内▲未来已到!瓦拉内:稳坐近十年皇马后防主力的年轻人
-
-
叶舒华|《狂飙》6大反派:戏里长得奇形怪状,戏外娶貌美娇妻,个个幸福
-
-
-
有手就行PDD得意门生亲自道歉,小天这回应真大度,ES选手狂喷小天
-
-
「传染病」美国“病毒猎手”确诊:病毒能感染我,就可能感染任何人
-
经济日报|资产配置需求旺盛推动人民币汇率走强 离岸人民币对美元汇率一度升破“7”关口
-
#同花顺财经#鼎捷软件:公司持续关注包括5G在内的新技术在企业信息化的应用
-
#隔壁的小蜘蛛#火影:秽土转生那么BUG,就没有一些直接伤害灵魂的忍术吗?,原创
-
艾乐影评|小透明逆袭成女神,一举夺得健美比基尼冠军,健身4年
-
-
窗 铝合金耐火窗优点有什么 选购铝合金耐火窗需要注意什么
-
「电影」记得林正英电影中那个“小僵尸”吗?走红后销声匿迹,他怎么了