有一个具有这种结构的文件:
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;
}
答案 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";