我有一个C#WPF(.NET 4.0)应用程序,它使用Excel互操作从Excel文件中读取数据 .
当我在具有Excel 2007的开发机器上运行此应用程序时,它工作正常 . 当我在另一台安装了Excel 2010的计算机上运行它时,它失败并显示以下错误消息:
System.Runtime.InteropServices.COMException(0x80040154):由于以下错误,检索CLSID为{00024500-0000-0000-C000-000000000046}的组件的COM类工厂失败:80040154未注册类(HRESULT异常:0x80040154( REGDB_E_CLASSNOTREG)) .
尝试创建 Microsoft.Office.Interop.Excel.Application
对象时发生故障,如:
var app = new Application();
我的项目引用了 Microsoft.Office.Interop.Excel.dll
(版本14.0.0.0,运行时版本v2.0.50727),它位于:
C:\ Program Files \ Microsoft Visual Studio 10.0 \ Visual Studio工具用于Office \ PIA \ Office14 \ Microsoft.Office.Interop.Excel.dll
我尝试使用引用的dll上的默认设置运行应用程序:
-
Copy Local = False
-
嵌入互操作类型=真
-
具体版本=真
我还尝试在引用的dll上使用以下设置运行应用程序:
-
Copy Local = True
-
嵌入互操作类型=假
-
具体版本=真
但是在使用Office 2010的计算机上,这些尝试都没有奏效 .
其他说明:Office 2010的计算机是64位w / Windows 7.我的开发计算机是带有Windows XP的X86 .
Question
是什么导致“类未注册”异常,我该如何解决?
Edit
为了回应Alex的回答,我尝试将应用程序构建为任何CPU,X86和X64,但它没有任何区别 . 我仍然得到相同的“类未注册”错误 .
Edit 2
刚刚使用Office 2010在32位计算机上试用过该应用程序 . 没有错误 . 因此,特定机器可能出现问题,或者可能是64位和Office 2010的组合 .
Edit 3
好的,现在我已经在Office 2010的另一台64位计算机上测试了它 . 再次没有错误 . 我认为这意味着特定机器出了问题,这不是我软件的错 . 啊编程 .
1 回答
初步答案:我的软件很好,特定机器上的设置出了问题 .
Edit
我刚刚发现了一些可能是问题根源的东西 . 问题机器有Office,但它被设置为click-to-run(在互联网上运行)而不是MSI-based(从EXE运行) . 这意味着
Microsoft.Office.Interop.Excel
无法使用某些注册表设置,DLL,组件等,因此失败 .Edit 2
这绝对是个问题 . 刚升级到完整的基于MSI的Office安装,一切都很好 .
Edit 3
将此添加为Microsoft Connect的错误:
https://connect.microsoft.com/VisualStudio/feedback/details/672276/excel-interop-fails-on-machine-where-office-is-installed-as-click-to-run#details