How and Where to Use Enumerators

How to use Enumerators

Cells Enumerator

There are various ways to access the Cells Enumerator, and one can use any of these methods based on the application requirements. Here are the methods that return the cells enumerator.

  1. Cells.GetEnumerator
  2. Row.GetEnumerator
  3. Range.GetEnumerator

All of the above‑mentioned methods return an enumerator that allows traversing the collection of cells, which have been initialized.

The following code example demonstrates the implementation of the IEnumerator interface for a Cells collection.

Rows Enumerator

The Rows Enumerator can be accessed while using the RowCollection.GetEnumerator method. The following code example demonstrates the implementation of the IEnumerator interface for RowCollection.

Columns Enumerator

The Columns Enumerator can be accessed while using the ColumnCollection.GetEnumerator method. The following code example demonstrates the implementation of the IEnumerator interface for ColumnCollection.

Where to use Enumerators

In order to discuss the advantages of using enumerators, let’s take a real‑time example.

Scenario

An application requirement is to traverse all cells in a given Worksheet to read their values. There could be several ways to implement this goal. A few are demonstrated below.

Using Display Range

Using MaxDataRow & MaxDataColumn

As you can observe, both of the above‑mentioned approaches use more or less similar logic; that is, loop over all cells in the collection to read the cell values. This could be problematic for a number of reasons as discussed below.

  1. APIs such as MaxRow, MaxDataRow, MaxColumn, MaxDataColumn & MaxDisplayRange require extra time to gather the corresponding statistics. In case the data matrix (rows × columns) is large, using these APIs could impose a performance penalty.
  2. In most cases, not all cells in a given range are instantiated. In such situations, checking every cell in the matrix is not as efficient as checking only the initialized cells.
  3. Accessing a cell in a loop as Cells[row, column] will cause all cell objects in a range to be instantiated, which may eventually cause an OutOfMemoryException.

Conclusion

Based on the above‑mentioned facts, the following are the possible scenarios where enumerators should be used.

  1. Read‑only access to the cell collection is required; that is, the requirement is to only inspect the cells.
  2. A large number of cells are to be traversed.
  3. Only initialized cells/rows/columns should be traversed.