这是一个“让我们看看能不能完成”的练习。
假设我有一个包含几列的 DataTable。使用 linq,是否可以选择表的行,使得结果将是匿名类型的序列,其中匿名类型的每个属性根据 DataTable 的列名命名并设置每个属性的类型适当地。
因此,如果我的 DataTable 有三列,如下所示:
Name = "Column1", DataType = string
Name = "Column2", DataType = integer
Name = "Column3", DataType = bool
然后我想选择 DataTable 的所有行,使匿名类型具有三个属性:
DataSet ds = functionThatGetsADataSet();
var seq = ds.Tables[0].AsEnumerable().Select( r => **** MAGIC HERE ****)
foreach (var s in seq)
{
Console.WriteLine(s.Column1);
Console.WriteLine(s.Column2);
Console.WriteLine(s.Column3);
}
我知道我可以这样做:
DataSet ds = functionThatGetsADataSet();
var seq = ds.Tables[0].AsEnumerable().Select( r =>
new
{
Column1 = r.Field<string>("Column1"),
Column2 = r.Field<int>("Column2"),
Column3 = r.Field<bool>("Column3"),
}
)
foreach (var s in seq)
{
Console.WriteLine(s.Column1);
Console.WriteLine(s.Column2);
Console.WriteLine(s.Column3);
}
但这需要对 new 子句中的属性名称进行硬编码,而我希望属性名称来自 DataTable 的 Columns 集合。
我希望我已经足够清楚地解释了这一点。在玩了一点之后,我开始认为,就可读性和可维护性而言,我想出的任何东西都会是一团糟,但我想我会问。