0

有没有办法从 DataTable 中的单个列中提取所有项目,而不是使用 For Each 循环?

例如,以下从 DataTable 的单个列中的每一行构建一个 KeyValuePair 列表

List<KeyValuePair<string, double>> extract = new List<KeyValuePair<string, double>>();
foreach (DataRow item in _dataTableTest.Rows)
{
    KeyValuePair<string, double> selection = (KeyValuePair<string, double>)item["Selection"];
    extract.Add(selection);
}

有没有更好的方法和/或更快的方法来做到这一点?

4

1 回答 1

4

你可以使用Linq-To-DataTable

List<KeyValuePair<string, double>> extract = _dataTableTest.AsEnumerable()
          .Select(r => r.Field<KeyValuePair<string, double>>("Selection"))
          .ToList();

请注意,您需要添加using System.Linq;并且这在性能方面并不是“更快”。它还在内部使用循环。

于 2012-10-05T22:25:32.113 回答