Python多线程下调用win32com包相关问题:pywintypes.com_error: (-2147221008, ‘尚未调用 CoInitialize。‘, None, None)问题处理

简介: Python多线程下调用win32com包相关问题:pywintypes.com_error: (-2147221008, ‘尚未调用 CoInitialize。‘, None, None)问题处理
+关注继续查看

报错1:

pywintypes.com_error: (-2147221008, '尚未调用 CoInitialize。', None, None)


场景:

我是用 flask 服务操作接收的请求,通过 xlwings 库读取 excel。


问题原因:

多线程下使用 win32com 的话,前面必须调用 CoInitialize,而 xlwings 读取 excel 正好用到了 win32com。


解决方法:

导入 pythoncom 库,如果没有的话可以通过 pip install pywin32 安装。

然后线程前面加一句这个即可 pythoncom.CoInitialize()

import pythoncom

# 多线程
thread():
    # 这个必须有
    pythoncom.CoInitialize()
    
    # 其它代码
    ...
    
    # 这个可有可无
    pythoncom.CoUninitialize()

报错2:

pywintypes.com_error: (-2147417842, '应用程序调用一个已为另一线程整理的接口。', None, None)

如果创建 xlwings 对象的过程在外面,读取的过程在里面会报这个错。

问题代码示例:

import pythoncom

# 创建xlwings对象
app = xlwings.App(visible=False, add_book=False)

# flask下的路由
@app_flask.route('/get_data/<command>')
@cross_origin()
def get_data(command):
    pythoncom.CoInitialize()
    
    # 使用xlwings对象打开excel
    wt = app.books.open(path_xl_new1)
    
    # 其它代码
    ...
    
    pythoncom.CoUninitialize()

正确代码示例:

import pythoncom

# flask下的路由
@app_flask.route('/get_data/<command>')
@cross_origin()
def get_data(command):
    pythoncom.CoInitialize()
    
    # 创建xlwings对象也放在里面
    app = xlwings.App(visible=False, add_book=False)
    # 使用xlwings对象打开excel
    wt = app.books.open(path_xl_new1)
    
    # 其它代码
    ...
    
    pythoncom.CoUninitialize()

喜欢的点个赞❤吧!

目录
相关文章
|
18小时前
|
存储 Unix Shell
Python中的模块与包
Python中的模块与包
11 1
|
1天前
|
Python
安装python包管理工具pip
安装python包管理工具pip
12 1
|
1天前
|
开发者 Python
< Python全景系列-7 > 提升Python编程效率:模块与包全面解读
< Python全景系列-7 > 提升Python编程效率:模块与包全面解读
4 0
|
1天前
|
消息中间件 网络协议 Python
|
13天前
|
Python
Python程序结构:模块和包的组织与导入
Python程序结构:模块和包的组织与导入
12 0
|
17天前
|
Python
Python模块、包
Python模块、包
7 0
|
23天前
|
IDE 程序员 开发工具
22【Python基础】VS2019中使用Python及安装Python包
要使用Python语言来写一些程序,使用哪个IDE是个问题,若是专业开发Python,PyCharm无疑是最佳选择,作为使用VS较多的程序员,直接在VS中写Python是个不错的选择。本文主要介绍VS2019中安装Python环境、安装后环境配置、使用pip install ***安装Python包的过程。
19 0
|
25天前
|
Python
【从零学习python 】38.Python包的使用及导入方式
【从零学习python 】38.Python包的使用及导入方式
24 0
|
30天前
|
存储 Python
python--导入,模块的引用,包,__name__
python--导入,模块的引用,包,__name__
|
1月前
|
uml Python
将python源码自动生成UML图——扩张包Graphviz+Pyreverse
将python源码自动生成UML图——扩张包Graphviz+Pyreverse
38 0
相关产品
云迁移中心
推荐文章
更多