首页 技术 正文
技术 2022年11月16日
0 收藏 700 点赞 2,250 浏览 1915 个字

当PR在SAP里面已不再使用时,可使用批量使用以下两个BAPI进行处理:

BAPI_REQUISITION_DELETE,进行删除处理, (速度快)

BAPI_PR_CHANGE,进行关闭,但不删除(速度较慢),需要加COMMIT

需要注意的是:如果PR信息不完整或有错误,BAPI无法对PR进行处理

Public Function DELPR()
Dim BAPI As Object, Exps As Object, MSGList As Object, PRList As Object
Dim rng, I As Integer, J As Integer
CHK01:
If SAPOn = False And I < 1 Then
LogOnSAP
I = I + 1
GoTo CHK01
ElseIf SAPOn = True Then
Set BAPI = SAP.Add(“BAPI_REQUISITION_DELETE”)
Set Exps = BAPI.Exports(“NUMBER”)
Set MSGList = BAPI.TABLES(“RETURN”)
Set PRList = BAPI.TABLES(“REQUISITION_ITEMS_TO_DELETE”)

‘PR列表,第10列X作删除标示,第二行PR号,第三行PR行号
Set rng = Sheet1.Range(“A1:N5000”)
For I = 2 To 192

If rng(I, 10) = “X” Then
Exps.Value = rng(I, 1)
PRList.AppendRow
PRList(1, 1) = rng(I, 2)
PRList(1, 2) = “X”

BAPI.call

‘检查输出信息

‘MsgBox MSGList(1, 3)
End If
Next
End If
End Function

’——————————————————-

‘BAPI_PR_CHANGE对PR进行关闭:
Public Function CHCPR()
Dim BAPI As Object, Exps As Object, MSGList As Object, PRList As Object
Dim ITM As Object, ITMX As Object, CMMT As Object
Dim rng, I As Integer, J As Integer
Application.ScreenUpdating = False
Application.Calculation = xlCalculationManual
CHK01:
If SAPOn = False And I < 1 Then
LogOnSAP
I = I + 1
GoTo CHK01
ElseIf SAPOn = True Then
Set BAPI = SAP.Add(“BAPI_PR_CHANGE”)
Set CMMT = SAP.Add(“BAPI_TRANSACTION_COMMIT”)
Set Exps = BAPI.Exports(“NUMBER”)
Set ITM = BAPI.TABLES(“PRITEM”)
Set ITMX = BAPI.TABLES(“PRITEMX”)
Set MSGList = BAPI.TABLES(“RETURN”)
Set rng = Sheet1.Range(“A1:N5000”)
For I = 2 To 170

‘PR列表,第10列X作删除标示,第二行PR号,第三行PR行号
If rng(I, 10) = “X” Then
Exps.Value = rng(I, 1)
ITM.Rows.RemoveAll
ITMX.Rows.RemoveAll
ITM.AppendRow
ITM(1, “PREQ_ITEM”) = rng(I, 2) ‘PUR_GROUP
‘ITM(1, “PUR_GROUP”) = “308”
‘ITM(1, “PREQ_PRICE”) = “0.01”
‘ITM(1, “ITEM_CAT”) = “”
ITM(1, “CLOSED”) = “X” ‘CLOSED ITEM_CAT/FIXED/PREQ_PRICE

ITMX.AppendRow
ITMX(1, “PREQ_ITEM”) = rng(I, 2)
‘ITMX(1, “PREQ_ITEMX”) = “X”
‘ITMX(1, “PUR_GROUP”) = “X”
‘ITMX(1, “PREQ_PRICE”) = “X”
‘ITMX(1, “ITEM_CAT”) = “X”
ITMX(1, “CLOSED”) = “X” ‘CLOSED DELETE_IND

BAPI.Call
CMMT.Call

‘检查输出信息
‘MsgBox MSGList(1, 4)
End If
Next
Application.ScreenUpdating = True
Application.Calculation = xlCalculationAutomatic
End If
End Function

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,918
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,444
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,255
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,069
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,701
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,741