设为首页
加入收藏
发布文章
  首页   操作系统   系统集成   程序设计   网站设计   图形图象   安全技术   反击技术   硬件DIY   认证考试   免费资源
当前位置:中国E盟 -=> 程序设计 -=> VC++ -=> 正文  
用VC#2005解析含有多种格式的文本文件 << C++启蒙之用C++制作程序 | 用VC写一个完整的屏幕保护程序 >> 
 发布日期:2006-10-15 23:24:32 发布者:[佚名]  来源:[本站]  浏览:[]  评论:[ 字体:   

  如果您的文本文件含有多种格式,应该使用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 = "电话";
 
 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);
 }
}


  请注意:

  在使用Visual Basic的My对象(或是说My快捷方式)之前,必须先在项目中添加对Microsoft.VisualBasic.dll的引用,然后如下所示导入适当的命名空间:

using Microsoft.VisualBasic.Devices;

  如此一来,就可以在Visual C# 中使用与My相似的语法来撰写程序。

]]>
打印 】【 收藏 】【 推荐 】 
相关文章 推荐文章 热门文章
用VC写一个完整的屏幕保护程序[10.15]
 ·暂无
木马是如何编写的
VC-摄像头控制SDK源码
常用的图象处理函数的整理
深入浅出VC++串口编程之第三方类
创建高权限进程
 评一评
正在读取…
  笔名:
  评论:
   
【注】 发表评论必需遵守以下条例:
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款

设置首页 - 加入收藏 - 关于我们 - 联系我们 - 友情连接 - -

Copyright ©2006-2008 中国E盟 Powered By:www.chinaE.org

湘ICP备05004075号