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

相关推荐
大霞上仙7 分钟前
Ubuntu系统电脑没有WiFi适配器
linux·运维·电脑
Karoku06643 分钟前
【企业级分布式系统】Zabbix监控系统与部署安装
运维·服务器·数据库·redis·mysql·zabbix
为什么这亚子1 小时前
九、Go语言快速入门之map
运维·开发语言·后端·算法·云原生·golang·云计算
布值倒区什么name1 小时前
bug日常记录responded with a status of 413 (Request Entity Too Large)
运维·服务器·bug
。puppy2 小时前
HCIP--3实验- 链路聚合,VLAN间通讯,Super VLAN,MSTP,VRRPip配置,OSPF(静态路由,环回,缺省,空接口),NAT
运维·服务器
颇有几分姿色2 小时前
深入理解 Linux 内存管理:free 命令详解
linux·运维·服务器
光芒再现dev2 小时前
已解决,部署GPTSoVITS报错‘AsyncRequest‘ object has no attribute ‘_json_response_data‘
运维·python·gpt·语言模型·自然语言处理
AndyFrank3 小时前
mac crontab 不能使用问题简记
linux·运维·macos
成都古河云3 小时前
智慧场馆:安全、节能与智能化管理的未来
大数据·运维·人工智能·安全·智慧城市
算法与编程之美3 小时前
文件的写入与读取
linux·运维·服务器