SAP与tracker使用

简介: SAP与tracker使用

一. Tracker基本使用

1. Tracker基本概念介绍

  • Scripting Object: 展示SAP元素树, 可以展开与折叠
  • ID: 元素的ID, 通过ID确定唯一对应的元素
  • Text: 元素的文本内容, 如用户, 口令等, 没有文本的元素则Text内容为空
  • Type: 元素类型, 不同的元素类型有不同的属性与方法
2. 基本使用方法
  • SAP程序, 选择目标服务器, 进入登录页面
  • 打开tracker程序, 在Analyse会话框中, 点击扫描SAP会话

  • 出现类似 /app/com[0]ses[0]/wnd[0 ]的元素ID之后, 表明tracker已经与SAP正常创建了会话.
  • 进入Recorder会话框, 点击python, 与红色的Record按钮, tracker将一python代码的形式记录我们对SAP操作的过

  • 记录完成后点击黄色的Stop script process按钮, 再将tracker记录的python代码应用在自己的流程中

二. python代码与tracker

1.python创建SAP连接
import win32com.client
# 连接已经启动的SAP程序,获取COM(Component Object Model)对象,用于组件交互sap_gui_auto =win32com.client.Getobject("SAPGUI")# 获取脚本引擎对象
application =sap_gui auto.GetscriptingEngine# 获取连按
connect =application.children(0)
# 获取session,会话
session = connect.children(0)

注意:Children函数中参数的选择根据我们的会话实际情况选择,如果只开一个窗口,通常选择0即可,下图所示,打开了两个connect窗口,就存在两个connect,只需要选择需要的链接索引即可,session也是同理

2. 登录SAP
  • findById(), 参数为元素的ID, 可以找到wnd中唯一对应的元素
#登录SAP,在SAP中操作登录步骤
session.findById("wnd[0]/usr/txtRSYST-BNAME").text ="rpafasc"
session.findById("wnd[0]/usr/pwdRSYST-BCODE").text = "********"
session.findById("wnd[0]/usr/pwdRSYST-BCODE").setFocus()
session.findById("wnd[0]/usr/pwdRSYST-BCODE").caretPosition = 9session.findById("wnd[0]").sendvkey(0)
3. 进入供应商行项目, 并输入搜索条件
# 在SAP中进行相关操作,最后复制使用
# 输入事务代码
session.findById("wnd[0]/tbar[0]/okcd").text = "fb11n"  #点击回车键
session.findById("wnd[0]").sendvKey(0)
# 输入搜索条件
session.findById("wnd[0]/usr/ctxtKD_BUKRS-LOW").text=“2023"  # 输入公司代码session.findById("wnd[0]/usr/ctxtPA STIDA").text ="22.11.2022" # 输入目标日期session.findById("wnd[0]/usr/txtPA_NMAX").text =“5" # 输入最大行数session.findById("wnd[0]/usr/txtPA_NMAX").setFocus()
session.findById("wnd[0]/usr/txtPA NMAX").caretPosition =10
session.findById("wnd[0]/tbar[1]/btn[8]").press()#点击确认进入表格页面
session.findById("wnd[1]/tbar[0]/btn[0]").press()
4.SAP表格操作
4.1 选择行
#双击,获取表格元素的ID
table_id="wnd[0]/usr/cnt1GRID1/shellcont/she11/she11cont[1]/she11" # 获取表格元素
table_ele= session.findById(table_id)
# 获取表格最大行数
max_row = table_ele.RowCount
# 选择行
table_ele.selectedRows ="1"  # 1未行索引,索引从0开始,这里表示第2行table_ele.selectedRows=“1,2" # 选择多行,第2行与第3行
4.2 读取目标单元格内容
#逐行遍历目标列单元格内容
for row_index in range(table_ele.Rovcount):
    # GetCe11Value参数1为行索引,参数2为列名,在SAP中双击列,即可获取列名
    print("凭证编号:"",table_ele.Getce1lValue(row_index, "BELNR"))
相关文章
|
8月前
|
安全 数据处理 Python
Python 函数式编程:让代码更简洁高效
Python 函数式编程:让代码更简洁高效
478 107
|
并行计算
最新YOLOv8(2023年8月版本)安装配置!一条龙傻瓜式安装,遇到问题评论区提问
最近需要使用YOLOv8,百度了一下现在网上大多数教程都是比较早期的教程,很多文件已经大不相同,于是我根据官方readme文档,总结了一套安装方法,只需要按照本教程,复制每一段代码,按照教程配置好相应文件即可直接使用。
10242 2
|
数据安全/隐私保护
【VBScript】vbs 错误未结束的错误字符串常量
【VBScript】vbs 错误未结束的错误字符串常量
417 0
|
存储 BI 数据库
PowerApps教程-实现简单的增删改查
PowerApps是Microsoft提供的低代码开发平台,允许用户无需编写大量代码,通过直观的界面设计快速创建应用程序。通过PowerApps的数据连接功能,系统可以轻松地与其他Microsoft 365服务(如SharePoint、Excel)进行集成,实现数据的无缝交互。本文详细介绍了如何使用PowerApps快速开发一个支持增删改查的报表页面,采用SharePoint上的List作为数据源。
685 0
|
6月前
|
JSON 监控 API
n8n错误处理全攻略:构建稳定可靠的自动化工作流
在n8n自动化工作流中,错误是提升系统可靠性的关键。本文详解常见错误类型、节点级与全局处理机制,结合重试、熔断、补偿事务等高级模式,助您构建稳定、可维护的生产级自动化流程。
|
存储 人工智能 JSON
用 SAP ABAP 接入国内 AI 产品通用接口技术指南 1、调用AI接口
SAP 系统与国内先进的 AI 产品(如百度文心一言、阿里通义千问、字节跳动云雀模型、华为盘古大模型、豆包、Deepsheek 等)集成通用接口技术指南
1925 23
|
Kubernetes 架构师 Java
史上最全对照表:大厂P6/P7/P8 职业技能 薪资水平 成长路线
40岁老架构师尼恩,专注于帮助读者提升技术能力和职业发展。其读者群中,多位成员成功获得知名互联网企业的面试机会。尼恩不仅提供系统化的面试准备指导,还特别针对谈薪酬环节给予专业建议,助力求职者在与HR谈判时更加自信。此外,尼恩还分享了阿里巴巴的职级体系,作为行业内广泛认可的标准,帮助读者更好地理解各职级的要求和发展路径。通过尼恩的技术圣经系列PDF,如《尼恩Java面试宝典》等,读者可以进一步提升自身技术实力,应对职场挑战。关注“技术自由圈”公众号,获取更多资源。
|
存储 缓存 JavaScript
三个小时vue3.x从零到实战(前)(vue3.x基础)
该文章系列提供了Vue3.x从基础到实战的教程,涵盖安装、基本语法、组件化应用及项目构建等多个方面,适合从零开始学习Vue3.x的开发者。
2433 0
|
UED C++ Python
GUI开发入门指南
GUI开发入门指南

热门文章

最新文章

下一篇
开通oss服务