python与sap_Python结合SAP GUI Script操作sap的简易教程

众所周知,如果要用Python做一些桌面WIN32应用的自动化工作,就需要用到著名的pywin32尤其是其中的win32com.client模块,pywin32的安装不能直接通过pip install方法,奉上pywin32的官方github链接:https://github.com/mhammond/pywin32/releases。选择与桌面系统版本、python版本对应的版本安装即可:

如果一切正常,在Ipython中导入该模块时不会报异常!如:

In [1]: import win32com.client

接下拉就是建立与sap GUI的连接,如下:

1 SapGuiAuto = win32com.client.GetObject("SAPGUI")2 if not type(SapGuiAuto) ==win32com.client.CDispatch:3 return

4

5 application =SapGuiAuto.GetScriptingEngine6 if not type(application) ==win32com.client.CDispatch:7 SapGuiAuto =None8 return

9

10 connection =application.Children(0)11 if not type(connection) ==win32com.client.CDispatch:12 application =None13 SapGuiAuto =None14 return

15

16 session =connection.Children(0)17 if not type(session) ==win32com.client.CDispatch:18 connection =None19 application =None20 SapGuiAuto =None21 return

代码的剩余部分可以通过sap原生的“脚本回放与录制”功能生成vbs脚本语句,直接插入python代码中即可!

需要强调的是,脚本录制功能并不会记录下所有鼠标键盘操作,过程中如果有些窗口是操作系统本身窗口,依旧需要结合windows句柄的捕获、结合sendmessage、postmessage等win32 API函数来处理。

当然,还需要查阅sap gui script的帮助文件,里面会列出所有的sap底层对象的属性、方法、对应的参数类型、数量等,界面如下:

在我的一项实际工作中,需要获得一个shell表单的某个类似于excel 单元格的值,表格是ALV格式的,但是实际录制中没法录制到单元格值,也许你绞尽脑汁,最后通过其他方法(比如 用sendkey结合 ctrl + Y,CTRL + C)达到了同样的效果,但是笔者依然推荐用sap script 原生的API来解决。通过查阅SAP GUI知道它属于“GuiGridView Object”,具有方法“GetCellValue Method”,方法如下:

Public Function GetCellValue( _

ByVal Row As Long, _

ByVal Column As String _

) As String

其中column参数为字符串string类型,通过录制sap脚本,双击对应可以录制到列名称,通常录制代码类似:

session.findById("wnd[0]/usr/cntlCTRL_CONTAINERBSEG/shellcont/shell").currentCellColumn = "SGTXT"

所以如果想要取得某个单元格(sap中称之为cell)的值,语法如下:

sgtxt = Table.GetCellValue(0, "SGTXT")

需要注明的是,SAP底层的ALV格式表格中行号是从 0开始的,如果想要知道表格共有多少数据行,两行代码即可搞定(表格的ID通过脚本录制即可得到):

Set Table = session.findById("wnd[0]/usr/cntlCTRL_CONTAINERBSEG/shellcont/shell")

tableRowCount= Table.RowCount

如果要获取sap窗口标题来辅助程序判断,语法也很简单,直接调用session对象的text属性即可,如:

window_caption=session.findById("wnd[0]").Text

这些属性方法的操作看似简单,但是如果不查阅相关sap gui script API文档,对API不了解,你自己很难实验出来,也许勉强用别的方法实现,却难免走了弯路或者牺牲了稳定性。毕竟无论是VB、还是Python的编译器,都不会对sap底层的api进行代码提示和自动补充。所以必要时,务必要查阅“帮助文件”。

Scripting Tracker – Development Tool for SAP GUI Scripting,附上博客链接:https://blogs.sap.com/2014/11/20/scripting-tracker-development-tool-for-sap-gui-scripting/

内含scripting Tracker的下载链接:https://tracker.stschnell.de/

该工具比原生的sap script更加可视化更加易用,其中Analyser模块界面如下,依靠它可以清晰捕获到sap界面的树形结构和对应的元素id等属性:

你们关心的脚本录制工具recorder长这样,它支持录制脚本,且支持vb、python、java、powerShell等多种脚本语言的导出:

实在是良心应用,强烈推荐!

有了这些,用Python 控制操作SAP,从此不再是难事!

下面为一个python 操作sap打开T-code ”mm03“的简单示例,供参考:

1 #-Begin-----------------------------------------------------------------

2

3 #-Includes--------------------------------------------------------------

4 importsys, win32com.client5

6 #-Sub Main--------------------------------------------------------------

7 defMain():8

9 try:10

11 SapGuiAuto = win32com.client.GetObject("SAPGUI")12 if not type(SapGuiAuto) ==win32com.client.CDispatch:13 return

14

15 application =SapGuiAuto.GetScriptingEngine16 if not type(application) ==win32com.client.CDispatch:17 SapGuiAuto =None18 return

19

20 connection =application.Children(0)21 if not type(connection) ==win32com.client.CDispatch:22 application =None23 SapGuiAuto =None24 return

25

26 session =connection.Children(0)27 if not type(session) ==win32com.client.CDispatch:28 connection =None29 application =None30 SapGuiAuto =None31 return

32

33

34 #session.findById("wnd[0]").resizeWorkingPane(65, 19, 0)

35 session.findById("wnd[0]/tbar[0]/okcd").text = "mm03"

36 session.findById("wnd[0]").sendVKey(0)37 session.findById("wnd[0]/usr/ctxtRMMG1-MATNR").Text="9000000000012"

38 session.findById("wnd[0]").sendVKey(0)39 session.findById("wnd[1]/tbar[0]/btn[0]").press()40 session.findById("wnd[0]/usr/tabsTABSPR1/tabpSP02").select()41

42 except:43 print(sys.exc_info()[0])44

45 finally:46 session =None47 connection =None48 application =None49 SapGuiAuto =None50

51 #-Main------------------------------------------------------------------

52 if __name__ == "__main__":53 Main()54

55 #-End-------------------------------------------------------------------

PS:1、实际的sap脚本录制过程,会录制大量诸如 setfocus,caretposition,resizeWorkingPane等对程序无实际帮助的语句,为了提升程序执行效率,建议对录制的脚本语句进行适当注释和删除;

2、本文部分sap script api语句用的VB,需要适当修改才能运用到python中。

原文:https://www.cnblogs.com/new-june/p/NewJune.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/488955.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2019-2021年中国AI芯片市场预测与展望数据

来源:赛迪顾问预计未来三年AI芯片市场规模仍将保持50%以上的增长速度,到2019年中国AI芯片市场规模将达到124.1亿元。从细分市场结构来看,云端训练芯片的比例仍然最大,但增速最慢,云端推断芯片与终端推断芯片市场在未来…

java. oracle 存储文件,oracle调用java类遍历磁盘文件

利用oracle自带的utl_file包可以访问磁盘文件,但有个限制--无法访问文件夹?什么意思呢?就是说oracle只能访问指定的文件,而不能访问文件夹下的未知文件。所以,如果要通过oracle去遍历某指定路径下的所有文件&#xff0…

python装饰器用法_深入浅出分析Python装饰器用法

本文实例讲述了Python装饰器用法。分享给大家供大家参考,具体如下:用类作为装饰器示例一最初代码:class bol(object):def __init__(self, func):self.func funcdef __call__(self):return "{}".format(self.func())class ita(obje…

python安装(原系统中已有python2)

由于项目中需要使用python3的特征,例如对中文的支持而不使用unicode,虽然一般装系统的时候会带有python2版本,但是还需要重新安装。这里给大家说下,不需要卸载python2,只需要重装python3即可。 下载python3.4&#xff…

总经费8.4亿的上海市脑科学重大专项进展如何?且看2019年度工作汇报会

来源:复旦大学类脑智能科学与技术研究院12月23至24日,上海市“脑与类脑智能基础转化应用研究”市级科技重大专项2019年度工作汇报会在复旦大学召开。中国工程院原常务副院长、中国科学院院士、浙江大学教授潘云鹤,中科院脑科学与智能技术卓越…

路径中有中文怎么解决_时序路径分析

时序路径分析是STA中非常重要的一个部分,任何一条时序路径都是由下面的三条路径构成的:源时钟路径(source clock path)数据路径(data path)目标时钟路径 (destination clock paths)当…

创建启动oracle快捷方式,GNOME3创建连接OracleFS管理软件启动快捷方式

OS:Debian Gnu/Linux 9Java:openjdk version "1.8.0_151"OpenJDK Runtime Environment (build 1.8.0_151-8u151-b12-1~deb9u1-b12)OpenJDK 64-Bit Server VM (build 25.151-b12, mixed mode)方法:1、通过网页连接OraccleFS,并下载O…

bootstrap table 的简单Demo

暂时够用&#xff0c;不够用再补充 T_T script: <link rel"stylesheet" href"lib/bootstrap.min.css"> <!-- table css--> <link rel"stylesheet" href"lib/bootstrap-table.css"><script src"lib/jquery-1…

设计模式之——工厂模式

一、相关概念了解 首先知晓什么是工厂模式&#xff08;概念&#xff09;&#xff1f; ①实例化对象&#xff0c;用工厂方法代替new操作。②工厂模式包括工厂方法模式和抽象工厂模式。③抽象工厂模式是工厂方法模式的拓展。 其次明白工厂模式的意图 ①定义一个借口来创建对象&am…

吴恩达团队盘点2019AI大势:自动驾驶寒冬、NLP大跃进、Deepfake已成魔!

来源&#xff1a;新智元&#xff08;AI_era&#xff09;还有几天&#xff0c;我们就要和2019年说再见了。今年是AI从梦想变为现实的一年&#xff0c;从NLP到自动驾驶&#xff0c;从人脸识别到数据模拟&#xff0c;有哪些技术突破面世&#xff0c;又遭遇了哪些新的困难&#xff…

4怎么修边_亦木良品阻燃板怎么样

亦木良品阻燃板怎么样防火板_橱柜资料选择很重要美观耐用才是重点。橱柜资料1、防火板是由多层牛皮纸经酚醛树胶浸渍后与一层经浸渍的装饰纸在高温高压下压制而成&#xff0c;将防火板经冷压或热压在中密度板或刨花板上用作橱柜门板。普通防火板的耐磨、耐划、耐高温等性能要好…

QT:KeepAliveOption的应用

由于用QTcpSocket写网络通讯程序&#xff0c;当正常服务端或者客户端断开的时候&#xff0c;我们监测信号即可&#xff1a;Signals&#xff1a;stateChanged(QAbstractSocket::SocketState)。&#xff08;手动关闭网络连接&#xff0c;也会检测到断开&#xff09; 但是当若是有…

Science:2019年度最佳科学照片

来源&#xff1a;ScienceAAAS、DeepTech深科技摘要 《Science》杂志在 近日选出了在这一年中最受欢迎&#xff0c;也最具有视觉冲击力的照片。1、Weather above 天气之上摄影师、飞行员Santiago Borja在太平洋上空拍摄到的巨大雷暴。科学家希望知道这种风暴是否会将化学物质注…

多源异构数据_构建数字孪生城市的CIM数据平台哪家强?

文/王颖初 数字城市系统建设中数据领域存在的问题随着经济的发展和信息化水平的飞速提升&#xff0c;数字城市的系统建设也日益普及。数字城市涉及规划、建设、城市管理、国土、交通、水利、安防、人防、环境保护、文物保护、能源燃气等各大行业&#xff0c;及一切与智慧城市相…

behavior php,YII2框架中behavior行为的理解与使用方法示例

本文实例讲述了YII2框架中behavior行为的理解与使用方法。分享给大家供大家参考&#xff0c;具体如下&#xff1a;YII2中的行为说白了就是对组件功能的扩展&#xff0c;在不改变继承关系的条件下。行为附加到组件后&#xff0c;行为将注入自已的方法和属性到组件&#xff0c;可…

数字前端工程师必备技能

必备知识&#xff1a; 1.ASIC基础 &#xff08;1&#xff09;digital intergrated circut design &#xff08;数字集成电路设计&#xff09; &#xff08;2&#xff09;digital design principles and practices &#xff08;数字设计——原理与实践&#xff09; &#xff08;…

乐观锁和悲观锁_什么是悲观锁和乐观锁?

思维导图文章已收录Github精选&#xff0c;欢迎Star&#xff1a;https://github.com/yehongzhi/learningSummary悲观锁悲观锁是平时开发中经常用到的一种锁&#xff0c;比如ReentrantLock和synchronized等就是这种思想的体现&#xff0c;它总是假设别的线程在拿线程的时候都会修…

oracle session_wait,转载:学习Oracle动态性能表-(8)-V$SESSION_WAIT,V$SESSION_EVENT

(1)-V$SESSION_WAIT这是一个寻找性能瓶颈的关键视图。它提供了任何情况下session在数据库中当前正在等待什么(如果session当前什么也没在做&#xff0c;则显示它最后的等待事件)。当系统存在性能问题时&#xff0c;本视图可以做为一个起点指明探寻问题的方向。V$SESSION_WAIT中…

为了研究因果关系,原来科学家在这么多方向上都有尝试

来源&#xff1a;混沌巡洋舰1. 为何关注因果关系在现代科学之前&#xff0c;不管东西方&#xff0c;都是从经验出发&#xff0c;通过归纳获得知识&#xff0c;然而这样的知识&#xff0c;受限于观测&#xff0c;无法产生突破性的成果&#xff0c;在这样的模式下&#xff0c;再探…

[leetcode sort]56. Merge Intervals

Given a collection of intervals, merge all overlapping intervals. For example,Given [1,3],[2,6],[8,10],[15,18],return [1,6],[8,10],[15,18]. 合并重叠区间 1 class Solution(object):2 def merge(self, intervals):3 """4 :type i…