5

我正在尝试将列表绑定到gridview. 情况是这样的:我从 .txt 文件中获取数据,后来我把它放在第一个列表中List<Mycolumns>。我在创建的列表中有数据(有 3 个单独的列)。我正在从名为的列之一中获取数据System_Description。现在我想在 中显示这些数据gridview,但我得到的只是每行的长度。我应该如何解决它?这是我的代码。

private void button7_Click(object sender, EventArgs e)
    {
        List<MyColumns> list = new List<MyColumns>();

        OpenFileDialog openFile1 = new OpenFileDialog();
        openFile1.Multiselect = true;

        if (openFile1.ShowDialog() != DialogResult.Cancel)
        {
            foreach (string filename in openFile1.FileNames)
            {
                using (StreamReader sr = new StreamReader(filename))
                {
                    string line;
                    while ((line = sr.ReadLine()) != null)
                    {
                        string[] _columns = line.Split(",".ToCharArray());
                        MyColumns mc = new MyColumns();
                        mc.Time = _columns[0];
                        mc.System_Description = _columns[1];
                        mc.User_Description = _columns[2];
                        list.Add(mc);
                    }
                }
            }
            DataTable ListAsDataTable = BuildDataTable<MyColumns>(list);
            DataView ListAsDataView = ListAsDataTable.DefaultView;
            this.dataGridView1.DataSource = view = ListAsDataView;
            this.dataGridView1.AllowUserToAddRows = false;
            dataGridView1.ClearSelection();
        }

        List<string> description = list.Select(x => x.System_Description).ToList<string>();
        this.dataGridView2.DataSource = description;

    }
class MyColumns
{
    public string Time { get; set; }
    public string System_Description { get; set; }
    public string User_Description { get; set; }
}

编辑:

我已经阅读了DataBind()适用于 Web 表单的内容,我的应用程序是桌面应用程序。我现在该怎么办?

4

4 回答 4

3

我设法解决了这个问题。我是这样做的,也许它会对某人有所帮助。您可以使用DataTable,然后将DT 绑定到gridview。

DataTable dt = new DataTable();
dt.Columns.Add("values");

foreach(string items in description)
{
    DataRow row = dt.NewRow();
    dt.Rows.Add(items);
}
this.dataGridView2.DataSource = dt;
于 2013-07-22T12:12:44.603 回答
1

this.dataGridView1.DataSource = new BindingSource(list);

于 2013-07-22T10:53:31.850 回答
0

您仅System_Description使用以下语句选择字段:

List<string> description = list.Select(x => x.System_Description).ToList<string>();

然后你将此列表绑定到gridview:

this.dataGridView2.DataSource = description;

如果要将整个数据绑定到gridview; 只需将列表绑定为数据源。

this.dataGridView2.DataSource = list;
this.dataGridView2.DataBind();
于 2013-07-22T10:54:23.313 回答
-1

用这个

 this.dataGridView1.DataSource = description;

并在 aspx 的 gridview 中添加 Bound 字段。

<asp:BoundField DataField="System_Description" HeaderText="System_Description"></asp:BoundField>
于 2013-07-22T11:00:42.017 回答