gpt4 book ai didi

excel - SAP GUI 脚本打开一个 Excel 窗口,我无法停止它

转载 作者:行者123 更新时间:2023-12-04 21:02:36 61 4
gpt4 key购买 nike

我正在尝试自动将 SAP 导出到 Excel 文件,然后另一个带有一些 VBA 代码的 Excel 文件使用该文件来自动过滤和格式化数据。

我已经把它全部运行了,除了一个(看似很小的)问题:SAP总是自动打开导出的Excel文件,似乎没有办法阻止它,因为它似乎发生在在Excel VBA中导入数据的子例程之后已完成(它们包含 SAP GUI 脚本)。

如果我只运行 sap_export子程序,然后打开 Excel 文件,这简直令人讨厌。但是如果我运行 refresh_sap() , 调用 sap_export() ,后跟 refresh() ,它访问导出的 Excel 文件导入数据,我收到提示,告诉我该文件已在使用中。

我发现无法阻止文件被 SAP GUI 脚本打开,因为它似乎不会在运行时发生。我怀疑这就是为什么我找不到任何方法来使用 Application.Wait 或 DoEvents 来解决这个问题。不管我等多久,它都不起作用,因为文件在运行时之前永远不会打开。

Sub refresh_sap()       
Call sap_export
Call refresh
End Sub

Sub refresh()

'refreshes the connection to the SAP-exported Excel-file

ActiveWorkbook.Connections("export").refresh

'deleting unwanted data

ActiveWorkbook.Sheets("PC-Liste komplett").Select
Selection.AutoFilter
ActiveSheet.ListObjects("Tabelle_export").Range.AutoFilter Field:=4, Criteria1:="Löschen"
Range("A2").Select
Range(Selection, Selection.End(xlDown)).Select
Range(Selection, Selection.End(xlToRight)).Select
Selection.EntireRow.Delete
ActiveSheet.ListObjects("Tabelle_export").Range.AutoFilter Field:=4
Range("A1").Select
End Sub

Sub sap_export()

Dim set0 As Integer
Dim set1 As String
Dim set2 As Boolean

'vbs-script recorded with the SAP-GUI

If Not IsObject(sapp) Then
Set SapGuiAuto = GetObject("SAPGUI")
Set sapp = SapGuiAuto.GetScriptingEngine
End If
If Not IsObject(Scon) Then
Set Scon = sapp.Children(0)
End If
If Not IsObject(session) Then
Set session = Scon.Children(0)
End If
If IsObject(WScript) Then
WScript.connectobject session, "on"
WScript.connectobject sapp, "on"
End If

session.findById("wnd[0]/tbar[0]/okcd").Text = "/n KE5X"
session.findById("wnd[0]").sendVKey 0
session.findById("wnd[0]/usr/ctxtGT_PRCTR-LOW").Text = "*"
session.findById("wnd[0]").sendVKey 8
session.findById("wnd[0]/usr/cntlGRID1/shellcont/shell/shellcont[1]/shell").contextMenu
session.findById("wnd[0]/usr/cntlGRID1/shellcont/shell/shellcont[1]/shell").selectContextMenuItem "&XXL"

If session.findById("wnd[1]/usr/radRB_1").Selected = True Then
set0 = 0
ElseIf session.findById("wnd[1]/usr/radRB_2").Selected = True Then
set0 = 1
ElseIf session.findById("wnd[1]/usr/radRB_OTHERS").Selected = True Then
set0 = 2
End If

set1 = session.findById("wnd[1]/usr/cmbG_LISTBOX").Key
set2 = session.findById("wnd[1]/usr/chkCB_ALWAYS").Selected
session.findById("wnd[1]/usr/radRB_OTHERS").Select
session.findById("wnd[1]/usr/cmbG_LISTBOX").Key = "10"
session.findById("wnd[1]/usr/chkCB_ALWAYS").Selected = False
session.findById("wnd[1]").sendVKey 0
session.findById("wnd[1]/usr/ctxtDY_PATH").Text = "S:\FIN-Alle\Kostenstellen - Innenauftragsliste\SAP"
session.findById("wnd[1]/tbar[0]/btn[11]").press
session.findById("wnd[0]/usr/cntlGRID1/shellcont/shell/shellcont[1]/shell").contextMenu
session.findById("wnd[0]/usr/cntlGRID1/shellcont/shell/shellcont[1]/shell").selectContextMenuItem "&XXL"

Select Case set0
Case 0
session.findById("wnd[1]/usr/radRB_1").Select
Case 1
session.findById("wnd[1]/usr/radRB_2").Select
Case 2
session.findById("wnd[1]/usr/radRB_OTHERS").Select
End Select

session.findById("wnd[1]/usr/cmbG_LISTBOX").Key = set1
session.findById("wnd[1]/usr/chkCB_ALWAYS").Selected = set2
session.findById("wnd[1]").sendVKey 12
session.findById("wnd[0]/tbar[0]/okcd").Text = "/n"
session.findById("wnd[0]").sendVKey 0
End Sub

因为我的印象是我无法在子例程中关闭文件(因为它仅在运行时打开),所以我目前正在寻找一种方法:告诉 SAP 根本不要打开文件,或者禁止它无法访问 Excel,或者可能只是完全关闭 SAP 并查看它是否有效 - 尽管我不希望这样做。

最佳答案

据我所知,SAP SDK 导出函数总是使用一个虚拟文件来处理数据的导出。这是通过自动打开导出文件调用创建的。您可以尝试允许这样做,以便在调用 refresh() 方法后打开新的导出文件。见 http://rmps.cygnaltech.net/?p=779

关于excel - SAP GUI 脚本打开一个 Excel 窗口,我无法停止它,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33256214/

61 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com