python驱动SAP完成数据导出(二)
在上一篇 python驱动SAP完成数据导出(一)中,我们提到了数据导出前,SAP布局的重要性,如何识别当前布局模式,以及如何切换到想要的布局。本篇小爬将着重讲讲数据导出的注意事项。
我们可以通过如下方式进行导出:



其中方法一与方法三并无本质差别,最终都是可以脚本录制或者快捷键(Ctrl+Shift+F7)得到,点击导出按钮后,界面【选择电子表格】如下:

但是假如用户曾经勾选过上图中的【始终使用选定的格式】,那么则不会弹出上图所示窗口,直接进入如下界面:

注意一:
如果用户执行操作前没有点击【脚本录制】,则会弹出如下windows【另存为】界面:

由于该界面是windows系统窗体,无法通过脚本录制得到自动化脚本代码,所以我们务必要提前进行脚本录制动作,才能确保文件保存的界面可通过录制脚本得到代码。
注意二:
如果我们一开始选择的方法二 进行数据导出,则无论用户是否勾选【始终使用选定的格式】选项,SAP均会弹出【选择电子表格】界面。
因此,为了避免操作界面不一致带来的代码兼容问题,小爬建议大家使用方法二来执行数据导出。
最后的导出界面,用户可以设置保存的路径和文件名,最后基于各自的情况点击【生成】或者【替代】按钮(【替代】按钮,意味着如果设定目录中如果提前有同名文件,则会被新文件覆盖)。
点击完导出后,SAP会默认调用Excel进程,生成一个Excel文件,持续往该文件中传输值,待传输完毕后,SAP左下角会有消息显示:已传输***个字节。且该Excel文件会被excel自动打开。
那么问题来了,如果我们要通过脚本批量下载多个报表数据,则SAP会自动创建并打开N个excel文件,此举很有可能导致系统内存紧张甚至excel文件崩溃。因此我们有必要及时自动关闭Excel文件。这该如何处理呢?
显然,我们必须借助于windows系统api来实现,python下就必须依托于pywin32库。同时我们还要借助SPY++提前捕获窗口信息。


可以看到当系统是否隐藏了文件扩展名,最后窗口标题是有差别的,而FindWindow函数本身不支持基于窗口标题模糊查找,我们代码里不得不特殊化处理。
基于前文提到的方法二导出的,具体的示例代码如下(FB03为例):
1 import sys, win32com.client,os,win32gui,win32con,time
2 def Main():
3 try:
4 SapGuiAuto = win32com.client.GetObject("SAPGUI")
5 application = SapGuiAuto.GetScriptingEngine
6 connection = application.Children(0)
7 if connection.DisabledByServer == True:
8 print("Scripting is disabled by server")
9 application = None
10 SapGuiAuto = None
11 return
12
13 session = connection.Children(0)
14 if session.Busy == True:
15 print("Session is busy")
16 session = None
17 connection = None
18 application = None
19 SapGuiAuto = None
20 return
21
22 if session.Info.IsLowSpeedConnection == True:
23 print("Connection is low speed")
24 session = None
25 connection = None
26 application = None
27 SapGuiAuto = None
28 return
29
30 session.findById("wnd[0]").maximize()
31 session.findById("wnd[0]/usr/cntlGRID1/shellcont/shell").contextMenu()
32 session.findById("wnd[0]/usr/cntlGRID1/shellcont/shell").selectContextMenuItem("&XXL")
33 session.findById("wnd[1]/tbar[0]/btn[0]").press()
34 session.findById("wnd[1]/usr/ctxtDY_PATH").text = os.getcwd() #保存路径
35 session.findById("wnd[1]/usr/ctxtDY_FILENAME").text = "reportList.xlsx" #保存文件名
36 session.findById("wnd[1]/tbar[0]/btn[11]").press() #点击【替代】,覆盖可能的原文件
37 sapInfo=session.findById("wnd[0]/sbar").text #由于SAP脚本自身的特性,当程序读到左下角消息时,意味着数据已经传输完成!
38
39 '''找到打开的excel文件,并自动关闭它'''
40 excelHwnd=0
41 while ExcelHwnd==0:
42 time.sleep(0.2)
43 excelHwnd=max(win32gui.FindWindow("XLMAIN","reportList.XLSX - Excel"),win32gui.FindWindow("XLMAIN","reportList - Excel"))
44
45 '''以防SAP没有完全释放Excel进程,建议等待excel窗口可见后,再关闭它'''
46 isVisible=False
47 while isVisible==False:
48 time.sleep(0.2)
49 isVisible=win32gui.IsWindowVisible(excelHwnd)
50
51 '''关闭excel进程'''
52 win32gui.SendMessage(excelHwnd,win32con.WM_CLOSE,None,None)
53
54
55 except Exception as e:
56 print(e)
57 print(sys.exc_info()[0])
58
59 finally:
60 session = None
61 connection = None
62 application = None
63 SapGuiAuto = None
64
65 Main()
各位筒子,赶快动手试下吧o(* ̄▽ ̄*)ブ
快来扫码关注我的公众号 获取更多爬虫、数据分析的知识!

python驱动SAP完成数据导出(二)的更多相关文章
- python驱动SAP完成数据导出(一)
写在前面 我们使用Python驱动SAP时,经常会需要导出一些SAP报表数据至本地Excel文件.这个看似简单的问题背后,其实暗藏玄机,今天小爬就带各位同学好好捋捋. 以事务代码FB03(凭证清单)为 ...
- Python 把数据库的数据导出到excel表
import io,xlwt def export_excel(request): """导出数据到excel表""" list_obj = ...
- python selenium中Excel数据维护(二)
接着python里面的xlrd模块详解(一)中我们我们来举一个实例: 我们来举一个从Excel中读取账号和密码的例子并调用: ♦1.制作Excel我们要对以上输入的用户名和密码进行参数化,使得这些数据 ...
- VBA驱动SAP GUI实现办公自动化(一)
小爬之前写过一系列Python驱动SAP GUI实现办公自动化的文章,其实如果我们的实际业务不是太复杂,且我们对VBA语法比较熟悉的话,我们完全可以借助Excel VBA来驱动SAP GUI做很多自动 ...
- 【基于WinForm+Access局域网共享数据库的项目总结】之篇二:WinForm开发扇形图统计和Excel数据导出
篇一:WinForm开发总体概述与技术实现 篇二:WinForm开发扇形图统计和Excel数据导出 篇三:Access远程连接数据库和窗体打包部署 [小记]:最近基于WinForm+Access数据库 ...
- API例子:用Python驱动Firefox采集网页数据
1,引言 本文讲解怎样用Python驱动Firefox浏览器写一个简易的网页数据采集器.开源Python即时网络爬虫项目将与Scrapy(基于twisted的异步网络框架)集成,所以本例将使用Scra ...
- Matlab处理数据导出Paraview可读的vtk文件(二)
由于我在用SPH方法仿真时用的是FORTRAN语言,并且没有找到直接输出vtk文件的代码,因此偷懒通过MATLAB转换一下数据. 用到的Matlab子程序可通过一下链接找到. Matlab处理数据导出 ...
- Neo4j 第十二篇:使用Python驱动访问Neo4j
neo4j官方驱动支持Python语言,驱动程序主要包含Driver类型和Session类型.Driver对象包含Neo4j数据库的详细信息,包括主机url.安全验证等配置,还管理着连接池(Conne ...
- python打造漏洞数据导出工具
功能 [x] 支持导出的数据:IP地址.漏洞名称.风险等级.整改建议.漏洞描述.漏洞CVE编号.漏洞对应端口.漏洞对应协议.漏洞对应服务等. [x] 导出不同端口的同一个漏洞,也就是一个端口对应一个漏 ...
随机推荐
- shell脚本 微信/钉钉验证登录服务器
一.简介 登录用户需要二次验证码进行验证 可以配合 监控用户登录,发送通知给企业微信/钉钉 来使用 脚本放到/etc/profile.d/ 目录,登录的时候自动触发 二.微信脚本 1.需要修改Crop ...
- Hibernate框架使用之环境搭建
第一步:引入所需的jar包 第二步:创建实体类,配置实体类与数据表的映射关系 创建实体类 User.java package cn.hao.entity; public class User { /* ...
- 华为HMS Core图形引擎服务携手三七游戏打造移动端实时DDGI技术
在2021年HDC大会的主题演讲中提到,华为HMS Core图形引擎服务(Scene Kit)正协同三七游戏一起打造实时DDGI(动态漫反射全局光照:Dynamic Diffuse Global Il ...
- canvas绘制圣诞树
最近不知道咋的都玩起了用备忘录手绘圣诞树,作为万能的程序员,肯定也要跟上潮流,那用代码来实现圣诞树吧.哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈 实现效果如下: ...
- 论文翻译:2021_MetricGAN+: An Improved Version of MetricGAN for Speech Enhancement
论文地址:MetricGAN+:用于语音增强的 MetricGAN 的改进版本 论文代码:https://github.com/JasonSWFu/MetricGAN 引用格式:Fu S W, Yu ...
- yum安装curl支持http2
yum 安装 安装 yum 源 rpm -ivh http://mirror.city-fan.org/ftp/contrib/yum-repo/city-fan.org-release-2-1.rh ...
- PowerShell配置文件后门
PowerShell 配置文件是在 PowerShell 启动时运行的脚本. 在某些情况下,攻击者可以通过滥用PowerShell配置文件来获得持久性和提升特权.修改这些配置文件,以包括任意命 ...
- JAVA实现智能分词(通过文章标题生成tag标签)
导入jar包 IKAnalyzer2012_u6.jar下载链接:https://pan.xunlew.com/s86789 maven <dependency> <groupId& ...
- 【LeetCode】203. Remove Linked List Elements 解题报告(Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 双指针 递归 日期 题目地址:https://lee ...
- 1119 机器人走方格 V2
1119 机器人走方格 V2 基准时间限制:1 秒 空间限制:131072 KB M * N的方格,一个机器人从左上走到右下,只能向右或向下走.有多少种不同的走法?由于方法数量可能很大,只需要输出Mo ...