Python多线程下调用win32com包相关问题:pywintypes.com_error: (-2147221008, ‘尚未调用 CoInitialize。‘, None, None)问题处理
Posted 挣扎的蓝藻
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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()
喜欢的点个赞❤吧!
以上是关于Python多线程下调用win32com包相关问题:pywintypes.com_error: (-2147221008, ‘尚未调用 CoInitialize。‘, None, None)问题处理的主要内容,如果未能解决你的问题,请参考以下文章