Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/linq/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 使用lambda表达式遍历DataTable列_C#_Linq_Lambda_Datatable - Fatal编程技术网

C# 使用lambda表达式遍历DataTable列

C# 使用lambda表达式遍历DataTable列,c#,linq,lambda,datatable,C#,Linq,Lambda,Datatable,我想使用lambda表达式遍历DataTable列。目前我正在尝试使用ForEach。下面是示例代码 foreach (DataColumn x in registeredpeople.Columns) { Response.Write(tab + x.ColumnName); tab = "\t"; } 我想实现这样的目标,我们可以通过收集列表来实现 exampleCollection.ForEach(x => { sample.ID = x.Value,

我想使用lambda表达式遍历
DataTable
列。目前我正在尝试使用
ForEach
。下面是示例代码

foreach (DataColumn x in registeredpeople.Columns)
{
    Response.Write(tab + x.ColumnName);
    tab = "\t";
}
我想实现这样的目标,我们可以通过收集列表来实现

exampleCollection.ForEach(x =>
{
    sample.ID = x.Value,
    sample.Name = x.Text
});
列表的方法,因此必须将该集合转换为列表。但这真的值得付出努力吗

registeredpeople.Columns  // returns a DataColumnCollection 
    .Cast<DataColumn>()   // needed because DataColumnCollection doesn't implement IEnumerable<T> but just the non-generic IEnumerable(its old) 
    .ToList()             // needed because you want to use a method of List<T>, created a new List and fills it in a loop
    .ForEach(col => Console.WriteLine(col.ColumnName));
registeredpeople.Columns//返回DataColumnCollection
.Cast()//需要,因为DataColumnCollection不实现IEnumerable,而只实现非泛型IEnumerable(其旧版本)
.ToList()//之所以需要,是因为您想使用List方法,创建了一个新列表并将其填充到循环中
.ForEach(col=>Console.WriteLine(col.ColumnName));

当然,
foreach
更有效,而且您从
foreach

中没有任何好处。请问您为什么要这样做?为什么标准的
foreach
不好?@Magnus不是因为
foreach
不好。我只是想在我的应用程序中保持一致性,只要可能,我就使用lambda表达式而不是
foreach
。我觉得lambda表达式可以让代码变得干净。你应该阅读C#编译器团队的Eric Lippert的《对它的看法》: