扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
private void CH1_DemoForm035_Load(object sender, EventArgs e) { txtResult.Text = File.ReadAllText(@"Text\多格式文本文件.txt"); DataGridView1.ColumnHeadersVisible = true; // 设定栏标题样式。 DataGridViewCellStyle columnHeaderStyle = new DataGridViewCellStyle(); columnHeaderStyle.BackColor = Color.Beige; columnHeaderStyle.Font = new Font("Verdana", 9, FontStyle.Bold); DataGridView1.ColumnHeadersDefaultCellStyle = columnHeaderStyle; // 设定 DataGridView 控件的数据行数目。 DataGridView1.ColumnCount = 3; // 设定各数据行的标题名称。 DataGridView1.Columns[0].Name = "类别编号"; DataGridView1.Columns[1].Name = "类别名称"; DataGridView1.Columns[2].Name = "说明"; DataGridView1.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells; DataGridView2.ColumnHeadersVisible = true; DataGridView2.ColumnHeadersDefaultCellStyle = columnHeaderStyle; // 设定 DataGridView 控件的数据行数目。 DataGridView2.ColumnCount = 4; // 设定各数据行的标题名称。 DataGridView2.Columns[0].Name = "产品编号"; DataGridView2.Columns[1].Name = "产品名称"; DataGridView2.Columns[2].Name = "单位数量"; DataGridView2.Columns[3].Name = "单价"; DataGridView2.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells; DataGridView3.ColumnHeadersVisible = true; DataGridView3.ColumnHeadersDefaultCellStyle = columnHeaderStyle; // 设定 DataGridView 控件的数据行数目。 DataGridView3.ColumnCount = 3; // 设定各数据行的标题名称。 DataGridView3.Columns[0].Name = "货运公司编号"; DataGridView3.Columns[1].Name = "货运公司名称"; DataGridView3.Columns[2].Name = "电话"; DataGridView3.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells; } private void btnParseTextFiles_Click(object sender, EventArgs e) { using (TextFieldParser myReader =new TextFieldParser(@"Text\多格式文本文件.txt")) { // 定义三种格式之各栏的宽度与分隔字符。 int[] FirstFormat = { 5, 10, -1 }; int[] SecondFormat = { 6, 10, 17, -1 }; string[] ThirdFormat = { "," }; this.DataGridView1.Rows.Clear(); this.DataGridView2.Rows.Clear(); this.DataGridView3.Rows.Clear(); string[] CurrentRow; while (!myReader.EndOfData) { try { string RowType = myReader.PeekChars(2); switch (RowType) { case "CK": myReader.TextFieldType = FieldType.FixedWidth; myReader.FieldWidths = FirstFormat; // 或是myReader.SetFieldWidths(FirstFormat); CurrentRow = myReader.ReadFields(); this.DataGridView1.Rows.Add(CurrentRow); break; case "PB": myReader.TextFieldType = FieldType.FixedWidth; myReader.FieldWidths = SecondFormat; // 或是myReader.SetFieldWidths(SecondFormat); CurrentRow = myReader.ReadFields(); this.DataGridView2.Rows.Add(CurrentRow); break; case "SP": myReader.TextFieldType = FieldType.Delimited; myReader.Delimiters = ThirdFormat; // 或是myReader.SetDelimiters(ThirdFormat); CurrentRow = myReader.ReadFields(); this.DataGridView3.Rows.Add(CurrentRow); break; } } catch (MalformedLineException ex) { MessageBox.Show("行" + ex.Message + " 是无效的。略过。"); } } // 排序各个 DataGridView 控件的内容。 DataGridView1.Sort(DataGridView1.Columns[0], System.ComponentModel.ListSortDirection.Ascending); DataGridView2.Sort(DataGridView2.Columns[0], System.ComponentModel.ListSortDirection.Ascending); DataGridView3.Sort(DataGridView3.Columns[0], System.ComponentModel.ListSortDirection.Ascending); } } |
如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。