用VC#2005解析含有多种格式的文本文件

2016-02-19 15:07 8 1 收藏

最近很多朋友喜欢上设计,但是大家却不知道如何去做,别担心有图老师给你解答,史上最全最棒的详细解说让你一看就懂。

【 tulaoshi.com - 编程语言 】

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

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

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

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

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

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

  采用逗号分隔的数据行。

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

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

  以下的程序代码示范如何将多格式文本文件.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相似的语法来撰写程序。

来源:http://www.tulaoshi.com/n/20160219/1608908.html

延伸阅读
标签: PHP
  首先是保证文本文件可读写,在文件准备写入之前,我们所要做的是处理好用户留言! 这项工作可以在提交表格前进行,我们将得到的数据各项用特定的符号分开,比如说用&号,值得说明的是如果提交的数据中如果也包含有特定字符,那我们只好将他转化成其他形式,这一点各位自有办法; 如是我们得到数据形如: $str=”aaaaa&bbbbb&...
/*    * 简单的读/写文本文件的示例    * 这里包含了三个例子,即    * 1. 将文件读入到内存(这里是StringBuffer)的例子    * 2. 将内容中的文本写到文件    * 3. 将一个文件的内容读出来写入另一个文件中 &n...
标签: 办公软件
在工作中,有可能需要将大量Word的DOC文档格式转换为TXT文本文件格式。如果转换量少,可以在Word中利用“另存为”命令,但是当转换量比较大的时候用“另存为”的方法就很麻烦也很慢了,我们下面介绍如何在Word中利用“转换向导”快速完成这个任务的方法。具体操作以Word2003为例,其它版本可以参照进行。 1. 为了便于管理和操作,我们先...
标签: 电脑入门
Linux系统中如果你想要搜索文本文件的话,可以使用grep命令,通过grep命令,你可以搜索相关关键词文件,也可对符合条件的文本文件进行筛选,是个比较常用的命令,下面图老师小编就给大家介绍下Linux使用grep命令搜索文本文件的方法。 grep的工作方式是这样的,它在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须被引用,模板后...
标签: PHP
  动态实时发布新闻的程序,可以根据发布时间,自动地排列显示顺序。新闻文件为存储在指定目录的文本文件组成,当有新闻的时候,程序会自动地将其显示出来,并且排列在页面的最开始部分。 <html <head <titleNews</title </head <body bfcolor="#ffffff" <h1News</h1 <div aligh="cente...

经验教程

651

收藏

56
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部