使用 VBA 宏来调用 ABAP 代码


请尝试使用如下脚本 −

Dim sapConn As Object
\Declaring a connection object
Set sapConn = CreateObject("SAP.Functions")

\Creating an ActiveX object
sapConn.Connection.user = "username"
sapConn.Connection.Password = "xxxx"
sapConn.Connection.client = "client#"
sapConn.Connection.ApplicationServer = "Application Server”
sapConn.Connection.Language = "PT"

If sapConn.Connection.Logon(0, True) <> True Then //Checking connection here
   MsgBox "Not able to login to SAP"
Else
   MsgBox "Login Successful !!"
End If
Dim rfcAcctDocCheck As Object
Dim oAcctHeader As Object
Dim otAcctAR, otAcctGL, otAcctAP, otAcctAMT, otReturn As Object

Set rfcAcctDocCheck = sapConn.Add("BAPI_ACC_DOCUMENT_CHECK")
Set oAcctHeader = rfcAcctDocCheck.Exports("DOCUMENTHEADER")
Set otAcctGL = rfcAcctDocCheck.Tables("ACCOUNTGL")
Set otAcctAR = rfcAcctDocCheck.Tables("ACCOUNTRECEIVABLE")
Set otAcctAP = rfcAcctDocCheck.Tables("ACCOUNTPAYABLE")
Set otAcctAMT = rfcAcctDocCheck.Tables("CURRENCYAMOUNT")
Set otReturn = rfcAcctDocCheck.Tables("RETURN")
               Dim qtLegs As Integer
Dim dt, comp, tpDoc, docRef, tpAcct, acct, customer, vendor, _
   curr, val, spLedger, ccenter, order As String
Dim curLine As Integer

For lin = 1 To UBound(reg)
   id = Format(tbPost.Cells(reg(lin).lin_ini, K_COL_ID), "0000000000")
   dt = getDate(tbPost.Cells(reg(lin).lin_ini, K_COL_DT))
   comp = getCompanyCode(tbPost.Cells(reg(lin).lin_ini, K_COL_EMPR))
   tpDoc = getDocumentType(tbPost.Cells(reg(lin).lin_ini, K_COL_TP_DOC))
   docRef = tbPost.Cells(reg(lin).lin_ini, K_COL_DOC_REF)
   otAcctGL.freeTable
   otAcctAR.freeTable
   otAcctAP.freeTable
   otAcctAMT.freeTable
oAcctHeader("USERNAME") = sapConn.Connection.user
oAcctHeader("HEADER_TXT") = "Excel"
oAcctHeader("COMP_CODE") = comp
oAcctHeader("DOC_DATE") = dt
oAcctHeader("PSTNG_DATE") = dt
oAcctHeader("DOC_TYPE") = tpDoc
oAcctHeader("REF_DOC_NO") = docRef
otAcctAMT.Rows.Add
otAcctAMT(otAcctAMT.Rows.Count, "ITEMNO_ACC") = Format(leg, "0000000000")
otAcctAMT(otAcctAMT.Rows.Count, "CURRENCY") = curr
otAcctAMT(otAcctAMT.Rows.Count, "AMT_BASE") = val
Next
If rfcAcctDocCheck.Call = False Then
   MsgBox rfcAcctDocCheck.Exception
End If

更新于: 2020 年 2 月 14 日

514 次浏览

开启你的 职业生涯

通过完成课程获得认证

开始
广告