我有一些存储数据的列表
List<List<string>> data = new List<List<string>>();
如何正确分配它dataGridView.DataSource
?
我有一些存储数据的列表
List<List<string>> data = new List<List<string>>();
如何正确分配它dataGridView.DataSource
?
List<List<string>> data = new List<List<string>>();
dataGridView.DataSource = data;
dataGridView.Databind();
正如一些海报所说,这是针对 Windows 窗体的,在这种情况下,您可以(根据 MSDN)jst 设置数据源而不是数据绑定
这里的问题是(显然)DataGridView DataSource 属性不知道如何显示List<List<string>>
. 一种方法是将您的列表组合成一个 DataGridView 可以绑定的对象。这里有几种方法可以做到这一点:
到数据表:
要将您转换List<List<string>>
为 DataTable,我借用了此处的代码并创建了此扩展方法:
static class ListExtensions {
public static DataTable ToDataTable(this List<List<string>> list) {
DataTable tmp = new DataTable();
tmp.Columns.Add("MyData");
// Iterate through all List<string> elements and add each string value to a new DataTable Row.
list.ForEach(lst => lst.ForEach(s => tmp.Rows.Add(new object[] {s})));
return tmp;
}
}
现在您可以使用此扩展方法从您的 DataTable 中获取List<List<string>>
您可以绑定到 DataGridView 的数据表:
dataGridView.DataSource = data.ToDataTable();
对于匿名类型 List:
这是执行此操作的代码:
dataGridView.DataSource = data.SelectMany(lst => lst)
.Select(s => new { Value = s }).ToList();
我们需要匿名类型,因为如果没有一点帮助,DataGridView 将无法在 List 属性中显示字符串值,如此处所述。
当然,这两种方法都有缺点,但我确实相信这些方法是您的最佳选择。