Is there a reason why I can't do the following:
foreach (var Item in DataTable.Rows) {
rather than having to do
foreach (DataRow Item in DataTable.Rows) {
I would have thought this was possible, like it is on other datatypes. For example:
foreach (var Employee in Staff) { // string[] Staff etc...
When I try the first foreach loop, I get the the error CS0021: Cannot apply indexing with [] to an expression of type 'object'.
Why can't the compiler figure out that .Rows returns a collections of DataRows?
Rows
effectively returnsIEnumerable
(DataRowCollection
), so the compiler can only pickobject
as the type forvar
. UseRows.Cast<DataRow>
if you want to usevar
.Cast
is defined on Enumerable, so you have to include System.Linq.Brian is absolutely right about the reason for this, but there's a simpler way of avoiding it: use DataTableExtensions.AsEnumerable():