com_error 尝试从 Django 视图中使用 win32com.client 获取 COM 对象时

com_error when trying to get COM object with win32com.client from Django view

我正在尝试将 SAP GUI 会话连接到我的 Django 项目,以便我可以通过使用 win32com.client 来处理 COM 对象来与之交互。当从 shell 工作时,我完全可以通过 运行 宁以下代码使它工作:

sap_gui = win32com.client.GetObject("SAPGUI")
application = sap_gui.GetScriptingEngine
connection = application.Children(0)
session = connection.Children(0)

如果我在 views.py Django 模块中使用此代码启动服务器,这也有效,并且我可以获得显示在我的 Django 视图中的会话信息。但是,我希望能够手动连接和断开此类会话,因为不同的用户需要连接到不同的会话,并且通过 运行 在开始时设置代码,我只能坚持第一个会话。

我一直在尝试通过在 views.py 中定义以下视图来实现此功能:

def dashboard(request):
  if request.method == 'POST' and 'SAP_button' in request.POST:
    # Get the COM object (SAP session in this case)
    sap_gui = win32com.client.GetObject("SAPGUI") # ERROR HERE
    application = sap_gui.GetScriptingEngine
    connection = application.Children(0)
    session = connection.Children(0)
    # This is just a test to see if I get the desired output from the COM object
    test = session.info.User
  return render(request, 'Users/dashboard.html', {'test': test})

表单('Users/dashboard.html')对应的html代码如下:

<form action="", method="POST">{% csrf_token %}
    <button type="submit", name="SAP_button">Connect SAP</button>
</form>

单击按钮时,请求按预期工作,但我得到以下 com_error(-2147221020, 'Invalid syntax', None, None)。此错误来自尝试获取 SAP COM 对象时的第一行:sap_gui = win32com.client.GetObject("SAPGUI").

看起来 运行 来自视图的代码无法访问 COM 对象,但我是 Django 的新手,甚至在研究此类错误时我也无法理解为什么会这样正在发生或可能 solution/workaround。感谢任何帮助。

经过更多研究,我最终找到了解决此问题的代码。 POST 请求后,Django 视图在另一个线程中 运行,因此需要为此类线程初始化 COM 库。我通过在获取 COMobject 之前添加以下代码行解决了这个问题:

import pythoncom
...
pythoncom.CoInitialize()
sap_gui = win32com.client.GetObject("SAPGUI") # ERROR SOLVED
...