Python多线程下调用win32com包相关问题:pywintypes.com_error: (-2147221008, ‘尚未调用 CoInitialize。‘, None, None)问题处理
2023-06-13 09:17:21 时间
报错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的源代码下载_官方下载python源码,编译linux版本的python「建议收藏」
- python要不要装pycharm-Python和pyCharm安装
- python多线程执行任务Threading
- python进制转换函数-Python中进制转换函数的使用
- Python入门系列(十一)一篇搞定python操作MySQL数据库
- python海龟作图红绿灯_海龟作图—用Python绘图
- python pytorch 版本,python 如何查看pytorch版本
- Python: 判断文件/目录是否存在
- 【Python专栏】机器学习和深度学习知识框架
- Python保存json_python保存json文件
- 用 Python 自动生成数据日报!
- Python列表常用的函数和方法(3)_Python自学第二十二节
- Python异步: 定义、创建和运行协程(5)
- Python:Excel自动化实践入门篇 甲
- Python 进阶指南(编程轻松进阶):十五、面向对象编程和类
- python-Python与MongoDB数据库-使用Python执行MongoDB查询(三)
- Python dir()和help()帮助函数
- python web后端开发工程师的面试总结详解程序员
- Python多线程结合队列下载百度音乐代码详解编程语言
- python端口扫描程序详解编程语言
- Python实现简单的缓存和缓存decorator详解编程语言
- python全栈开发-Day3 字符串详解编程语言
- 使用Python编程连接MySQL数据库(python连mysql)
- 如何使用Python安装MySQL(python安装mysql)
- 使用 Bokeh 为你的 Python 绘图添加交互性
- 如何在Linux中安装Python?(linux安装python)
- Linux下Python编程:从入门到精通(linux下python编程)
- 探寻python多线程ctrl+c退出问题解决方案