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()

喜欢的点个赞❤吧!

  • 9
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

挣扎的蓝藻

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值