- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
这三种方式有什么区别:
Application xlApp = new Application();
Workbooks xlWorkbooks = xlApp.Workbooks;
Workbook xlWorkbook = xlWorkbooks.Open(filePath);
Sheets xlSheets = xlWorkbooks.Sheets;
// 1. Way
Worksheet xlSheet = xlSheets["SheetName"] as Worksheet;
// 2. Way
Worksheet xlSheet = xlSheets.Item["SheetName"] as Worksheet;
// 3. Way
Worksheet xlSheet = xlSheets.get_Item("SheetName") as Worksheet;
1.方式描述为
Indexer object Microsoft.Office.Interop.Excel.Sheets.this
Reserved for internal use.
方法二:
Indexed property object Microsoft.Office.Interop.Excel.Sheets.Item
Returns a single object from a collection.
还有第 3 种方式:
[object Index]:object
(对于这种方式,ReSharper 推荐使用 2. 方式。)
所以,这 3 种方式的作用完全相同,但推荐使用哪一种,有何区别?我认为所有 COMObject 集合都有这 3 种可能性。
最佳答案
没有区别,随便挑。大多数程序员可能会使用 //1. Way
但如果 Resharper 提示它,那么请随意满足它的要求。 Resharper 可能反对,因为它将 Sheets 视为 .NET 类而不是 COM 接口(interface)。可以原谅的是,微软在这方面有点失手。
我将解释为什么您可以选择。 C# 语言总是对属性有非常严格的定义。 C# 设计者不喜欢的是带有参数的属性,而不是 One and Only,the indexer。一个类(this[])。然而,此类属性在 COM 中非常常见,尤其是在 Office 互操作中。
COM也有一个索引器的概念,大致就是一个类的默认属性是特殊的。它是具有 [DispId(0)] 的属性。就像 C# 索引器一样,它不必在表达式中命名。
Sheets.Item 属性的怪癖是它有错误的 [DispId]。由于某种原因,它是 170 而不是 0。默认属性是 Sheets._Default .这是您将在 //1. Way
中使用的属性。不知道这是怎么发生的,就像 19 年前的疏忽一样,他们无法再纠正了。
C# 团队在版本 4 中做出让步,允许在 COM 接口(interface)上使用索引属性。这就是您可以选择的原因,早期版本需要使用 get_Item() 方法,现在也支持 Item 属性。在运行时完全没有区别。
关于c# - []、get_Item() 和 Item[] 之间的 Excel Interop 区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31360204/
我正在使用 Microsoft.Office.Interop.Outlook 提取电子邮件附件: var MAPI = new Application().GetNamespace("MAPI");
突然得到一个 System.invalidcastexception: unable to cast COM object of type 'system._object' to interface
我正在尝试在兼容的渲染目标上使用 Gdi 和 Direct 2D 来渲染位图。我使用 D2D1_COMPATIBLE_RENDER_TARGET_OPTIONS_GDI_COMPATIBLE 选项创建
完整错误: Could not load file or assembly 'Interop.Microsoft.Office.Interop.Word' or one of its dependen
我正在尝试寻找一种使用 Office.Interop.Outlook COM 对象连接到其他邮箱的方法。目前我正在执行以下操作(在添加 COM 对象之后): var app = new Microso
我有一个用 C# 编写的应用程序,该应用程序当前向 LDAP 进行身份验证。我们希望扩展功能以支持 IBM 的 Tivoli Access Manager,它由一个策略服务器和一个 LDAP 服务器(
在 Visual Studio 中将 interop.excel 引用添加到我的 C# winform 后,我无法再“编辑并继续”...... 错误提示“正在修改“方法” ' 包含嵌入式互操作类型/成
我正在尝试创建 Excel 文件的 Worksheet 数组,但找不到正确的转换。 这是代码: Excel.Application app = new Excel.Application(); Exc
我正在使用 C# Interop 从工作表中获取一些值,但出现以下错误: Non-invocable member 'Microsoft.Office.Interop.Excel.Range.End'
我在 MVC 桌面应用程序中使用 Nuget 包 System.Data.SQLite。当我尝试清理解决方案时出现错误。我收到的错误消息是:无法删除文件“...bin\Debug\x64\SQLite
序列化异常:程序集“Microsoft.Office.Interop.Excel,Version=11.0.0.0,Culture=neutral,PublicKeyToken=71e9bce111e
我正在通过命令行将 magento 2.1.8 升级到 2.3.3,当我运行 composer update 命令时它显示以下错误。 包 container-interop/container-int
我正在尝试从 C# 控制台应用程序中的 Excel 中捕获一些数据。 我得到了错误 Unable to cast COM object of type 'microsoft.Office.Intero
我收到一个错误: Unable to cast COM object of type 'Microsoft.Office.Interop.Excel.ApplicationClass' to inte
我刚刚下载了 MS Visual Studio 2010 解决方案并收到该错误。 Error 1 Assembly 'Microsoft.Office.Interop.Word, Version=15
我尝试为 socket.io 编写一个绑定(bind)。 我在使用函数(底部示例代码中的 next())时遇到问题,该函数要么不带参数,要么带有错误对象( Js.Exn.raiseError("ERR
在 C++/CLI 中,是否可以固定不包含元素的数组? 例如 array^ bytes = gcnew array(0); pin_ptr pin = &bytes[0]; //。您可以回退到 GCH
我目前正在从事一个项目,该项目包含几种不同的“编程”语言,每种语言都有自己的命名约定。应该始终使用相同的命名约定,还是应该在每种语言中使用不同的名称以具有原生外观(即不与框架的其余部分冲突)? 例如,
我是Clojure和Java的新手。 为了访问Clojure中的Java字段,您可以执行以下操作: Classname/staticField 就是一样的 (. Classname staticFie
我想提取word文档中的项目符号信息。我想要这样的东西:假设下面的文字在 word 文档中: 启动汽车的步骤: 开门 坐在里面 关上门 插入 key 等等 然后我想要我的文本文件如下: 启动汽车的步骤
我是一名优秀的程序员,十分优秀!