无法将类型为“Microsoft.Office.Interop.Excel.ApplicationClass”的COM 对象强制转换为接口类型“Microsoft.Office.Interop.Exc
随风飘扬 学习 2017年09月05日8:04 2513
使用asp.net读取xls文件时报该错误,经过搜索得到解决方案顺利解决,经测试,该方法同样适用于W
使用asp.net读取xls文件时报该错误,经过搜索得到解决方案顺利解决,经测试,该方法同样适用于Word。
原文地址:http://www.cnblogs.com/sunxin88/articles/3456395.html
如果您使用的电脑要操作的是Office 2003而之前使用过Office 2007使用此方法可解决您的问题
无法将类型为“Microsoft.Office.Interop.Excel.ApplicationClass”的COM对象强制转换为接口类型“Microsoft.Office.Interop.Excel._Application”。此操作失败的原因是对 IID 为“{000208D5-0000-0000-C000-000000000046}”的接口的COM组件调用QueryInterface因以下错误而失败: 库没有注册。(异常来自HRESULT:0x8002801D (TYPE_E_LIBNOTREGISTERED))。英文版的异常消息如下:
Unable to cast COM object of type 'Microsoft.Office.Interop.Excel.ApplicationClass' to interface type 'Microsoft.Office.Interop.Excel._Application'. This operation failed because the QueryInterface call on the COM component for the interface with IID '{000208D5-0000-0000-C000-000000000046}' failed due to the following error: could not be found. (Exception from HRESULT: 0x80030002 (STG_E_FILENOTFOUND)).
出现的原因可能是安装Office时安装过不同版本造成的
本人安装的是Office 2013,并安装过Office 2016,也安装过Office Access 2007
解决办法:
在注册表中找到:
HKEY_CLASSES_ROOT\TypeLib\{00020813-0000-0000-C000-000000000046}\1.6、1.9 删除之
就可以了。
因为我用的是Office 2013对应的是1.8,所以删除1.6、1.9
Office 2007对应的是1.6,Office 2016对应的是1.9,所以要根据情况判断。
声明:凡本网转载的文/图等稿件,均出于传递更多信息及方便探讨之目的,并不意味着本站及主办、承办单位赞同其观点或证实其内容的真实性,文章内容仅供参考,如果侵犯了原作者的权利请与网站管理员联系。
评论列表
-
暂无数据