我正在尝试使用以下代码在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;
}
答案 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); }));
}
的更多信息
祝你好运!
答案 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