Analyzing your prompt, please hold on...
An error occurred while retrieving the results. Please refresh the page and try again.
An enumerator is an object that provides the ability to traverse a container or a collection. Enumerators can be used to read the data in the collection, but they cannot be used to modify the underlying collection, whereas IEnumerable is an interface that defines one method GetEnumerator which returns an IEnumerator interface, this, in turn, allows read-only access to a collection.
Aspose.Cells APIs provide a bunch of enumerators however, this article mainly discusses the three types as listed below.
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.
All of the above-mentioned methods return the 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.
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.
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.
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.
As you can observe that 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.
Based on above-mentioned facts, the following are the possible scenarios where enumerators should be used.
Analyzing your prompt, please hold on...
An error occurred while retrieving the results. Please refresh the page and try again.