SAP 技巧篇:Script脚本模拟人工操作批量录入数据

" 现在大环境都讲人工智能、自动化办公等场景的应用,这里我们介绍一下SAP本身自带的自动化工具**" 文章最后附最终脚本**

01


背景需求

SAP:批量录入工具:LSMW/BDC/Script 三大工具

LSMW:应用场景多,实现方法多,但有些事务代码不能录制;

BDC:需要一定开发经验,适用于开发者;

Script:需要简单开发经验,但是容易出错;

02


实现

第一步:系统设置

检查系统SAP脚本录制和回放功能有无启用

执行事务代码:RZ11

输入参数:sapgui/user_scripting

然后回车

如果当前值为FALSE则改为TURE,如果当前值为TURE,则表示已经启用,就不需要更改了,改完之后点击保存,会提示,如果系统重启服务,则需要在此更改这里的配置,否则就不生效了。

然后退出所有窗口,在SAP GUI中打开设置

点击启用脚本>应用>确认,后重启SAP GUI

第二步:脚本录制

进入脚本的录制:

点击增加

复制保存到后面的文件路径,打开文件,粘贴路径打开

此时该路径下已有13个脚本,可以更改路径脚本名称为14,如下图

然后点击红色按钮进行录制操作,就是把需要重复的动作在SAP内执行一遍,执行过程中不要有多余的操作,精简不必要的操作,录制完成之后回来点黄色按钮即录制完成。

绿色按钮为执行按钮,录入完成之后可以点这里执行脚本。

第三步:修改脚本,让脚本能重复执行:

找到对应脚本,点击鼠标右键,用记事本打开

END IF之前的不需要修改,直接忽略

然后在第一个session之前加入打开Excel与循环的语句,明确打开Excel位置和文件名:

复制代码
dim oExcel,oWb,oSheet

Set oExcel = CreateObject("Excel.Application")

Set oWb = oExcel.Workbooks.Open("D:\mmm.xls")

ON ERROR RESUME Next
for i = 2 to 623

然后修改文件路径:

复制代码
Set oWb = oExcel.Workbooks.Open("C:\Users\XXX\Desktop\10.xlsx")

为需要录入的数据源文档所在路径,这里按照保存路径修改;

for i = 2 to 2 为EXCL中从第几行开始到第几行结束,比如从第一行开始到第8行结束,则为for i = 1 to 8

把原来手工输入数据的地方,改为从excel中读取数据

比如

复制代码
session.findById("wnd[0]/usr/ctxtVBAK-VBELN").text = "1000001269"

改成

复制代码
session.findById("wnd[0]/usr/ctxtVBAK-VBELN").text = oExcel.Cells(i,1).Value

然后在最后加上关闭语句:

复制代码
next
oExcel.WorkBooks.Close
oExcel.Quit

最终Script脚本如下:

复制代码
If Not IsObject(application) Then
   Set SapGuiAuto  = GetObject("SAPGUI")
   Set application = SapGuiAuto.GetScriptingEngine
End If
If Not IsObject(connection) Then
   Set connection = application.Children(0)
End If
If Not IsObject(session) Then
   Set session    = connection.Children(0)
End If
If IsObject(WScript) Then
   WScript.ConnectObject session,     "on"
   WScript.ConnectObject application, "on"
End If
dim oExcel,oWb,oSheet
Set oExcel = CreateObject("Excel.Application")
Set oWb = oExcel.Workbooks.Open("C:\Users\SAIP\Desktop")
ON ERROR RESUME Next
for i = 1 to 8
session.findById("wnd[0]").maximize
session.findById("wnd[0]/tbar[0]/okcd").text = "VA02"
session.findById("wnd[0]").sendVKey 0
session.findById("wnd[0]/usr/ctxtVBAK-VBELN").text = oExcel.Cells(i,1).Value
session.findById("wnd[0]/usr/ctxtVBAK-VBELN").caretPosition = 10
session.findById("wnd[0]").sendVKey 0
session.findById("wnd[0]/mbar/menu[0]/menu[11]").select
session.findById("wnd[1]/usr/btnSPOP-OPTION1").press
next
oExcel.WorkBooks.Close
oExcel.Quit

原始脚本如下:

复制代码
If Not IsObject(application) Then
   Set SapGuiAuto  = GetObject("SAPGUI")
   Set application = SapGuiAuto.GetScriptingEngine
End If
If Not IsObject(connection) Then
   Set connection = application.Children(0)
End If
If Not IsObject(session) Then
   Set session    = connection.Children(0)
End If
If IsObject(WScript) Then
   WScript.ConnectObject session,     "on"
   WScript.ConnectObject application, "on"
End If
session.findById("wnd[0]").maximize
session.findById("wnd[0]/tbar[0]/okcd").text = "VA02"
session.findById("wnd[0]").sendVKey 0
session.findById("wnd[0]/usr/ctxtVBAK-VBELN").text = "1000001269"
session.findById("wnd[0]/usr/ctxtVBAK-VBELN").caretPosition = 10
session.findById("wnd[0]").sendVKey 0
session.findById("wnd[0]/mbar/menu[0]/menu[11]").select
session.findById("wnd[1]/usr/btnSPOP-OPTION1").press

第四:提示:

保存执行前SAP GUI只能留一个界面是打开的,然后直接运行Script脚本,

窗口会一步步在前台执行操作,直到结束,但如果有报错,会直接跳入到下一行数据,所以创建后一定要再检查数据,是否有错误,这里也是Script脚本的缺点。

脚本可以直接双击运行。

公告:周一至周五每日一更,周六日存稿,请您点"关注"和"在看",后续推送的时候不至于看不到每日更新内容,感谢。

这是一条刮刮乐,按住全部选中:点关注的人最帅最美,欢迎:分享+收藏+在看+点赞+关注!

Allways on the way

相关推荐
ulias21218 小时前
Linux系统中的权限问题
linux·运维·服务器
青花瓷19 小时前
Ubuntu下OpenClaw的安装(豆包火山API版)
运维·服务器·ubuntu
问简20 小时前
docker 镜像相关
运维·docker·容器
Dream of maid20 小时前
Linux(下)
linux·运维·服务器
齐鲁大虾20 小时前
统信系统UOS常用命令集
linux·运维·服务器
Benszen21 小时前
Docker容器化技术实战指南
运维·docker·容器
ZzzZZzzzZZZzzzz…21 小时前
Nginx 平滑升级:从 1.26.3 到 1.28.0,用户无感知
linux·运维·nginx·平滑升级·nginx1.26.3·nginx1.28.0
一叶知秋yyds1 天前
Ubuntu 虚拟机安装 OpenClaw 完整流程
linux·运维·ubuntu·openclaw
斯普信云原生组1 天前
Prometheus 环境监控虚机 Redis 方案(生产实操版)
运维·docker·容器
safestar20121 天前
ES批量写入性能调优:BulkProcessor 参数详解与实战案例
java·大数据·运维·jenkins