0

我有一些存储数据的列表

List<List<string>> data = new List<List<string>>();

如何正确分配它dataGridView.DataSource

4

2 回答 2

1
List<List<string>> data = new List<List<string>>();
dataGridView.DataSource = data;
dataGridView.Databind();

正如一些海报所说,这是针对 Windows 窗体的,在这种情况下,您可以(根据 MSDN)jst 设置数据源而不是数据绑定

于 2012-04-11T23:03:51.043 回答
1

这里的问题是(显然)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 属性中显示字符串值,如此所述。


当然,这两种方法都有缺点,但我确实相信这些方法是您的最佳选择。

于 2012-04-12T00:11:51.690 回答