如何将List <string>绑定到datagridView?</string>

时间:2013-04-22 13:28:40

标签: c# list datagridview bindinglist

我正在尝试使用以下代码在datagridview中显示List的内容。

List<string> data = new List<string>(); 
dataGridView1.DataSource = data;  

我将我的数据添加到backgroundWorker中的List中。如果我将列表更改为 BindingList ,则会收到错误消息

Cross-thread operation not valid: Control 'dataGridView1' accessed from a thread other than the thread it was created on.

但是如果我使用List,那么当显示datagrid时,我会得到第3列,它只包含Categories中每个条目的字符串的长度。

有没有人知道如何在使用BackgroundWorker时让datagrid显示字符串内容而不是字符串长度?


    private void OnBackgroundWorkerDoWork(object sender, DoWorkEventArgs e)
    {            
        importExcelFile();            
    }

    private void importExcelFile()
    {
        // hard coded file name for testing. 
        TextFieldParser parser = new TextFieldParser(@"E:\\test.csv");
        parser.TextFieldType = FieldType.Delimited;
        parser.SetDelimiters(",");

        while (!parser.EndOfData)
        {
            //Processing row
            string[] fields = parser.ReadFields();
            foreach (string field in fields)
            {
                //TODO: Process field
                data.Add(field);
            }
        }
        parser.Close();
    }

    private void loadFileToolStripMenuItem_Click(object sender, EventArgs e)
    {
        backgroundWorker1.DoWork += OnBackgroundWorkerDoWork;
        backgroundWorker1.RunWorkerAsync();
    }

    private void OnBackgroundWorkerRunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
    {
        dataGridView1.DataSource = data;
    }

4 个答案:

答案 0 :(得分:1)

您可以使用BackgroundWorker.ReportProgress传递列表。我允许传递进度和自定义对象(full dentition on MSDN)。处理此事件是UI线程,因此它是正确的。

如果最后需要这个,只需使用RunWorkerCompletedEventArgs.Result(again definition on MSDN

答案 1 :(得分:1)

请创建一个委托并使用control.Invoke

调用该委托

您可以像这样使用Invoke:

private void AddToListBox(object oo)
{
    Invoke(new MethodInvoker(delegate { listBox.Items.Add(oo); }));
}

有关Background Worker

的更多信息 祝你好运!

答案 2 :(得分:1)

基于How to bind a List<string> to a DataGridView control?

我创建了一个类

public class StringValue
{
    public StringValue(string s)
    {
        _value = s;
    }
    public string Value { get { return _value; } set { _value = value; } }
    string _value;
}

然后将列表更改为列表

我正在获取数据,但它出现在第3列中。我只假设有2列。

答案 3 :(得分:1)

使用此代码。我也面临类似的问题,但使用LinQ将其整理出来。

IList<String> listObj = new List<String>();
dataGridView1.DataSource = listObj.Select(x => new { Value = x }).ToList();

这里,

dataGridView1 :- ID of datagridview