- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我明白:
Range.Item
返回一个 Range 对象,该对象表示在指定范围的偏移处的范围。 Range.Cells
返回一个 Range 对象,该对象表示指定范围内的单元格。 Range
对象的默认属性”时,困惑就出现了。
Range("A1:D5").Cells(1,1)
真的是简化版
Range("A1:D5").Cells.Item(1,1)
?
Range("A1:D5").Item(1,1)
任何状况之下?
Cells
属性到引用范围而不是
Item
属性(property)?省略
Item
是“最佳实践”吗?支持
Cells
的默认属性?
最佳答案
Range
是一类。类是对象的蓝图——对象是类的一个实例。
现在,VBA 中的类可以有一个默认属性。如果你导出一个类模块,你可以给他们成员属性。 VB_UserMemId
属性,值为 0
, 将成员标识为该类的默认成员 - 您无法直接在 VBE 中编辑成员属性,但您可以导出模块、添加属性并将模块重新导入项目。
默认属性可能如下所示:
Option Explicit
Private mFoo As Bar
Public Property Get Foo() As Bar
Attribute Foo.VB_UserMemId = 0
Set Foo = mFoo
End Property
VB_UserMemId
您可以使用的值,但只有一个类的成员可以具有任何给定值 -
0
使其成为该类的默认成员。
i
处的项目时的
Collection
, 你可以这样做:
foo = myCollection.Item(i)
Item
是
Collection
的默认属性类,你也可以这样做:
foo = myCollection(i)
Range
类(Class)是……一种特殊的动物。如果您在对象浏览器中查看它的定义,您会发现它的默认属性是一个名为
_Default
的隐藏属性。 , 通常推断返回
Range.Value
- 因为这个隐式默认成员调用:
foo = Sheet1.Range("A1")
foo = Sheet1.Range("A1").Value
Item
Range
的属性(property)类不是默认成员。但是,如果您查看隐藏的定义
_Default
属性,您会看到它接受两个可选参数:
foo = Sheet1.Range("A1:A10")(1)
foo = Sheet1.Range("A1:A10").Item(1).Value
Range
类的默认属性的实现方式是,如果没有指定参数,它会做一件事(为您提供
Value
.. 它本身返回单元格的值,如果范围包含多个单元格,则返回二维变量数组),如果指定了参数,则另一件事(在该范围内的指定行/列中为您提供
Item
)。
Range("A1:A10").Cells
(没有参数)是多余的:它产生与
Range("A1:A10")
完全相同的单元格做。
Cells
属性未参数化:
Range.Cells
带参数,实际上是在调用
Range._Default
使用这些参数,根据
Cells
返回的范围... 这意味着
Range("A1:A10").Cells(1)
实际上是
Range("A1:A10").Cells.Item(1)
...这涉及对
Cells
的冗余调用.
Cells[._Default][.Item](1)
因此语法只是为了方便;它主要是可读性...然后是 IntelliSense:
Item
返回
Variant
,这意味着当您键入
.
时,您不会得到可用成员的漂亮小下拉列表。在它之后的点/取消引用运算符(调用是“后期绑定(bind)”,即所涉及的类型在运行时解析) - 但是当你调用
Cells
时你会这样做, 因为
Cells
返回早期绑定(bind)
Range
对象(即在编译时解析)。
Range
这与另一个最佳实践相冲突,即尽可能编写经过编译时验证的早期绑定(bind)代码 - 使用
Cells
而不是
Item
给你。
关于excel - 试图了解在 Range 对象上使用 Item 属性和 Cells 属性之间的区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51970397/
我创建了以下 sub 来简单地说明问题。我将事件工作表的范围 A2:E10 分配给范围变量。然后,对于另一个范围变量,我将这个范围的子范围,单元格 (1, 1) 分配给 (3, 3)。 我原以为这将包
我使用正则表达式来搜索以下属性返回的纯文本: namespace Microsoft.Office.Interop.Word { public class Range {
我正在开发一个宏来突出显示某些行/单元格以供进一步审查。一些值/空白将以红色突出显示,其他以橙色突出显示,而整行应为黄色。我从上一个问题中得到了一些帮助,并添加了更多细节,它工作得几乎完美,但我被困在
这个问题在这里已经有了答案: What is the difference between range and xrange functions in Python 2.X? (28 个答案) 关闭
我在尝试运行脚本时遇到这个奇怪的错误,代码似乎是正确的,但似乎 python (3) 不喜欢这部分: def function(x): if int
我正在编写一种算法,将一些数据写入提供的输出范围(问题的初始文本包括具体细节,这将评论中的讨论转向了错误的方向)。我希望它在 API 中尽可能接近标准库中的其他范围算法。 我查看了 std::rang
这按预期工作: #include #include int main() { auto chunklist = ranges::views::ints(1, 13) | ranges::vie
我这里有一个字符串,我正在尝试对其进行子字符串化。 let desc = "Hello world. Hello World." var stringRange = 1..' 的值转换为预期的参数类型
我有一个高级搜索功能,可以根据日期和时间查询记录。我想返回日期时间范围内的所有记录,然后从该范围内返回我想将结果缩小到一个小时范围(例如 2012 年 5 月 1 日 - 2012 年 5 月 7 日
Go 中的 range 函数和 range 关键字有什么区别? func main(){ s := []int{10, 20, 30, 40, 50, 60, 70, 80, 90}
如果我有一个范围,如何将其拆分为一系列连续的子范围,其中指定了子范围(存储桶)的数量?如果没有足够的元素,则应省略空桶。 例如: splitRange(1 to 6, 3) == Seq(Range(
我正在开发 VSTO Excel 项目,但在管理 Range 对象时遇到一些问题。 实际上,我需要知道当前选定的范围是否与我存储在列表中的另一个范围重叠。所以基本上,我有 2 个 Range 实例,我
在即将推出的 C++20 系列中,将有 range concept具有以下定义: template concept range = __RangeImpl; // exposition-only de
希望有人能回答我的问题。我在 VHDL 代码中遇到了这个命令,但不确定它到底做了什么。有人可以澄清以下内容吗? if ( element1 = (element1'range => '0')) the
可以将范围嵌套在范围中吗?使用范围内的变量?因为我想取得一些效果。为了说明这个问题,我有以下伪代码: for i in range(str(2**i) for i in range(1,2)):
我想在 2 个日期之间创建一个范围,并且我的范围字段有时间 damage_list = Damage.objects.filter(entry_date__range=(fdate, tdate))
在下面的代码中 #include #include #include int main() { std::unordered_mapm; m["1"]=1; m["2"]=2
我试图为我的电子表格做一个简单的循环,它循环遍历一个范围并检查该行是否为空,如果不是,则循环遍历一系列列并检查它们是否为空,如果是则它设置一个消息。 问题是每次它通过循环 ro.value 和 col
我在将一个工作簿范围中的值分配给当前工作簿中的某个范围时遇到问题。当我使用 Range("A1:C1") 分配我的范围时,此代码工作正常,但是当我使用 Range(Cells(1,1),Cells(1
我改写了原来的问题。 Sub s() Dim r As Range Set r = ActiveSheet.Range("B2:D5") Debug.Print r.Rows.Count
我是一名优秀的程序员,十分优秀!