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

更新时间:2023-07-09
报错1: pywintypes.com_error: (-2147221008, '尚未调用 CoInitialize。', None, None) 场景: 我是用 flask 服务操作接收的请求,通过 xlwings 库读取 excel。 问题原因: 多线程下使用 win32com 的话,前面必须调用 CoInitialize,而 xlwings 读取 excel 正好用到了 win32com。 解决方法: 导入 pythoncom 库,如果没有的话可以通过 pip install pywin32 安装。 然后线程前面加一句这个即可 pythoncom.CoInitialize() ```python import pythoncom # 多线程 thread(): # 这个必须有 pythoncom.CoInitialize() # 其它代码 ... # 这个可有可无 pythoncom.CoUninitialize() ``` 报错2: pywintypes.com_error: (-2147417842, '应用程序调用一个已为另一线程整理的接口。', None, None) 如果创建 xlwings 对象的过程在外面,读取的过程在里面会报这个错。 问题代码示例: ```python import pythoncom # 创建xlwings对象 app = xlwings.App(visible=False, add_book=False) # flask下的路由 @app_flask.route('/get_data/') @cross_origin() def get_data(command): pythoncom.CoInitialize() # 使用xlwings对象打开excel wt = app.books.open(path_xl_new1) # 其它代码 ... pythoncom.CoUninitialize() ``` ```python import pythoncom # flask下的路由 @app_flask.route('/get_data/') @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() ```