如何以及在何处使用枚举器

如何使用枚举器

Cells 枚举器

访问 Cells 枚举器的方法有很多种,可以根据应用程序的要求使用其中的任何一种方法。以下是返回单元格枚举器的方法。

  1. Cells.GetEnumerator
  2. Row.GetEnumerator
  3. 范围.GetEnumerator

所有上述方法都返回允许遍历已初始化单元格集合的枚举器。

下面的代码示例演示了 Cells 集合的 IEnumerator 接口的实现。

行枚举器

可以在使用时访问行枚举器行集合.GetEnumerator方法。下面的代码示例演示了 IEnumerator 接口的实现行集合.

列枚举器

可以在使用时访问列枚举器ColumnCollection.GetEnumerator方法。下面的代码示例演示了 IEnumerator 接口的实现列集合.

在哪里使用枚举器

为了讨论使用枚举器的优势,让我们举一个实时示例。

设想

一个应用需求是遍历给定的所有单元格工作表读取它们的值。可以有几种方法来实现这个目标。下面展示了一些。

使用显示范围

使用 MaxDataRow 和 MaxDataColumn

正如您所观察到的,上述两种方法都或多或少地使用了相似的逻辑,即;遍历集合中的所有单元格以读取单元格值。由于如下所述的多种原因,这可能会产生问题。

  1. API,例如最大行数, 最大数据行, 最大列, 最大数据列 & 最大显示范围需要额外的时间来收集相应的统计数据。如果数据矩阵(行 x 列)很大,使用这些 API 可能会造成性能损失。
  2. 在大多数情况下,并非给定范围内的所有单元格都被实例化。在这种情况下,与仅检查初始化单元格相比,检查矩阵中的每个单元格效率不高。
  3. 以Cells row,column的形式循环访问一个cell会导致一个范围内的所有cell对象都被实例化,最终可能导致OutOfMemoryException。

结论

基于上述事实,以下是应该使用枚举器的可能场景。

  1. 需要对单元格集合进行只读访问,即;要求是只检查细胞。
  2. 要遍历大量的单元格。
  3. 只遍历初始化的单元格/行/列。