设为首页 加入收藏

TOP

用VC#2005解析含有多种格式的文本文件
2014-11-23 22:55:20 】 浏览:333
Tags:VC#2005 解析 含有 多种 格式 文本 文件

  一般而言,文本文件都只会包含一种格式(例如,以逗号分隔或是固定字段宽度),然而文本文件却很可能含有多种格式,当遇到此种状况时该如何处理呢?


  如果您的文本文件含有多种格式,应该使用TextFieldParser对象的PeekChars方法去取得数据行从头算起特定数目的字符,以便藉此来判断该数据行的格式,然后告知TextFieldParser对象该数据行的格式为何并读取该数据行。PeekChars方法只会返回指定数目的字符而且不会前进至下一行,通过这样逐一判别每一笔数据行的格式并逐行读取数据行的方式,即可够解析含有多种格式的文字文件并顺利读取。


  举例来说,假设我们在应用程序项目的Text文件夹含有一个名称为“多格式文本文件.txt”的文本文件,此文本文件的特殊之处在于它含有下列三种格式:


  ·固定字段宽度分别为5、10与 -1的数据行。


  ·固定字段宽度分别为6、10、17与 -1的数据行。


  ·采用逗号分隔的数据行。


  上述这三种格式的数据行存在一个特点,就是数据行的开头字符分别是CK、PB与SP,因此我们只要通过TextFieldParser对象的PeekChars方法取得数据行的前两个字符,然后根据其值来设定TextFieldType属性,以及设定Delimiters属性(或调用SetDelimiters方法)或FieldWidths属性(或调用SetFieldWidths方法),并使用ReadFields方法来读取数据行。反复使用此方式来处理每一笔数据行,就能够顺利解析并读取整个文本文件。


  以下的程序代码示范如何将“多格式文本文件.txt”中的三种格式数据解析出来并分别显示于各自的DataGridView控件中。相关程序代码列示如下:


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 = "电话";


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇用C#和ADO.NET建立一个数据绑定网.. 下一篇在C#中建立复杂的、灵活的SQL查询..

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目