问题描述:使用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'
问题解决:
发生这个错误的原因并不是很清楚, 大概是升级了一下系统, 但是我并不清楚内部原因.
解决的方法就是, 因为这个缓存的文件有问题, 所以就应该删掉缓存. 所以我先找到这个缓存文件:
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.
然后你的程序又能顺利运行了.