填充列表框

时间:2009-11-14 12:43:41

标签: c#

有一个具有这种结构的文件:

  

companyname1; shortname1; identification1; 01.01.1980   companyname2; shortname2; identification2; 1987年1月1日   companyname3; shortname3; identification3; 1990年1月1日   companyname4; shortname4; identification4; 1995年1月23日

我想将所有“companynameX”放入listbox1,当点击每个项目时,相关的“identificationX”将显示在文本框中。 我非常愚蠢,对于这个简单的任务,我使用了DataTable。它不起作用,列表框中填充了一个项目,文本框中填入了“System.Data.DataRowView”。为什么它不起作用以及如何以更优雅的方式完成我的任务?

foreach (string line in File.ReadAllLines(@"D:\file.txt"))
{
    string[] parts = line.Split(';');

    DataSet ds = new DataSet();
    DataTable dt = new DataTable("dt");
    DataColumn dc;
    DataRow dr;
    dc = new DataColumn();
    dc.DataType = System.Type.GetType("System.String");
    dc.ColumnName = "First";
    dt.Columns.Add(dc);

    dc = new DataColumn();
    dc.DataType = System.Type.GetType("System.String");
    dc.ColumnName = "Second";
    dt.Columns.Add(dc);

    ds.Tables.Add(dt);
    for (int j = 2; j < parts.Length; j += 4)
    {
         for (int k = 0; k < parts.Length; k += 4)
         {
              dr = dt.NewRow();
              dr["First"] = parts[j];
              dt.Rows.Add(dr);

              dr = dt.NewRow();
              dr["Second"] = parts[k];
              dt.Rows.Add(dr);
          }
    }

    listBox1.DataSource = dt;
    listBox1.DisplayMember = "First";
    listBox1.ValueMember = "Second";
}

private void listBox1_SelectedIndexChanged(object sender, EventArgs e)
{
            string value = listBox1.SelectedItem.ToString();
            textBox1.Text = value;
}

1 个答案:

答案 0 :(得分:2)

var records = from line in File.ReadAllLines(@"D:\file.txt")
              let parts = line.Split(';')
              select new 
              {
                  Company = parts[0],
                  Identification = parts[2]
              };
listBox1.DataSource = records;
listBox1.DisplayMember = "Company";
listBox1.ValueMember = "Identification";