当我输入此foreach
声明时......
foreach (var row in table.Rows)
... var的工具提示说class System.Object
我很困惑为什么它不是class System.Data.DataRow
。
(如果您想知道,是的,我的代码文件顶部有using System.Data
。)
如果我明确声明类型,如......
foreach (DataRow row in table.Rows)
...它没有错误,工作正常。
如果我这样做......
var numbers = new int[] { 1, 2, 3 };
foreach (var number in numbers)
... var评估为struct System.Int32
。因此,问题不是var
在foreach
子句中不起作用。
因此,DataRowCollection
有一些奇怪的地方,其中的项目不会自动评估为DataRow
。但我无法弄清楚它是什么。有人有解释吗?
更新
我真的被撕裂了对Mark的回答(Codeka和Oliver)......最后,我决定标记Codeka,因为它真的回答了我的问题,但Oliver回答了我应该问的问题:)
答案 0 :(得分:17)
这是因为DataRowCollection类仅实现IEnumerable
的非泛型版本。所以编译器不知道变量的类型是什么。
通过明确地将类型放在那里,你基本上告诉编译器生成从object
到DataRow
的显式转换。
这是一个问题,你会发现许多集合和类在.NET 1.x天后添加回来,在泛型可用之前。
答案 1 :(得分:12)
虽然codeka是正确的,但还有一些其他方法可以让这些DataTable
和DataRow
更加方便。
使用.Net 3.5,您可以添加程序集System.Data.DataSetExtensions
。
它包含一些扩展函数,例如AsEnumerable(this System.Data.DataTable)
或Field<T>(this System.Data.DataRow, int)
,您可以在foreach循环中调用它并将列直接转换为正确的类型:
int columnIndex = 2;
foreach(var row in MyDataTable.AsEnumerable())
{
var content = row.Field<double>(columnIndex);
}