使用pywin32进行Excel操作,has no attribute 'CLSIDToClassMap'

问题描述:使用pywin32进行Excel操作,报如下错误: 

File "C:\Users\syd\AppData\Local\Programs\Python\Python35\lib\site-packages\win32com\client\gencache.py", line 552, in AddModuleToCache
dict = mod.CLSIDToClassMap
AttributeError: module 'win32com.gen_py.00020905-0000-0000-C000-000000000046x0x8x7' has no attribute 'CLSIDToClassMap'

问题解决: 

参考:https://mlln.cn/2018/04/23/win32com-gen-py%E9%94%99%E8%AF%AFhas-no-attribute-CLSIDToClassMap/index.html

发生这个错误的原因并不是很清楚, 大概是升级了一下系统, 但是我并不清楚内部原因.
解决的方法就是, 因为这个缓存的文件有问题, 所以就应该删掉缓存. 所以我先找到这个缓存文件:

from win32com.client.gencache import EnsureDispatch
import sys
xl = EnsureDispatch("Word.Application")
print(sys.modules[xl.__module__].__file__)

运行这段代码, 就会找到它的位置. 然后删除gen_py文件夹下的所有包含这一堆数字的文件夹0020905-0000-0000-C000-000000000046x0.

然后你的程序又能顺利运行了.

你可能感兴趣的:(python,python,pywin32,has,no,attribute,'CLSIDToClass,Excel)