Lau*_*ent 11 vb.net dll excel interop
当我在计算机上添加对Microsoft.Office.Interop.Excel的引用时,Visual Studio将其添加到项目文件中:
<COMReference Include="Excel">
<Guid>{00020813-0000-0000-C000-000000000046}</Guid>
<VersionMajor>1</VersionMajor>
<VersionMinor>5</VersionMinor>
<Lcid>0</Lcid>
<WrapperTool>primary</WrapperTool>
<Isolated>False</Isolated>
</COMReference>
Run Code Online (Sandbox Code Playgroud)
团队中还有另一个开发人员遇到错误并需要将一个DLL文件添加到名为Interop.Excel.dll的项目中,该项目在项目文件中用以下代码替换:
<Reference Include="Interop.Excel, Version=1.5.0.0, Culture=neutral, processorArchitecture=MSIL">
<SpecificVersion>False</SpecificVersion>
<HintPath>My Project\Interop.Excel.dll</HintPath>
</Reference>
Run Code Online (Sandbox Code Playgroud)
这适用于我的电脑.
您能否解释两种方法之间的差异,哪种方法最好,以及如何让第一种方法在其他计算机上运行?
Dir*_*mar 12
我也没有看到你的方法有问题.
通常,当您添加对组件的引用时,VS将自动为COM组件生成互操作程序集.但是,当您添加对其中一个Office组件(XP或任何更高版本)的引用时,将添加对Microsoft的预生成(和优化)主互操作程序集的引用,如第一个示例中所示.这条线
<WrapperTool>primary</WrapperTool>
Run Code Online (Sandbox Code Playgroud)
表示使用此PIA.
如果您正确添加了PIA引用,则此引用的CopyLocal属性应设置为false,并且Path属性应类似于
C:\WINDOWS\assembly\GAC\Microsoft.Office.Interop.Excel\12.0.0.0__71e9bce111e9429c\Microsoft.Office.Interop.Excel.dll
Run Code Online (Sandbox Code Playgroud)
您将在本MSDN 文章中找到有关互操作程序集的更多详细信息.
要使第一种方法正常工作,必须在计算机上安装Office主互操作程序集(PIA).Microsoft提供了可再发行版本:
AFAIK,这些PIA仅在安装.NET Framework时由Office安装程序安装,这就是为什么PIA有单独的可再发行组件的原因.
注意:确保引用您要定位的Office版本.在定位多个版本的Office时,您可能会遇到一些问题.在这种情况下的解决方案可能是后期绑定(如果性能不是问题).
我使用 Excel 自动化的方式比我愿意承认的要多,而且我从未引用过 Interop.Excel.dll。我一直引用前者。他为什么引用这个,他遇到了什么错误?
你们引用的是相同版本的 Excel(5.0 与 11.0)吗?你们有完全相同版本的 Office、service pakcs 等吗?这可能就是区别。
| 归档时间: |
|
| 查看次数: |
46924 次 |
| 最近记录: |