一般而言,文本文件都只會(huì)包含一種格式(例如,以逗號(hào)分隔或是固定字段寬度),然而文本文件卻很可能含有多種格式,當(dāng)遇到此種狀況時(shí)該如何處理呢?
如果您的文本文件含有多種格式,應(yīng)該使用TextFieldParser對(duì)象的PeekChars方法去取得數(shù)據(jù)行從頭算起特定數(shù)目的字符,以便藉此來(lái)判斷該數(shù)據(jù)行的格式,然后告知TextFieldParser對(duì)象該數(shù)據(jù)行的格式為何并讀取該數(shù)據(jù)行。PeekChars方法只會(huì)返回指定數(shù)目的字符而且不會(huì)前進(jìn)至下一行,通過(guò)這樣逐一判別每一筆數(shù)據(jù)行的格式并逐行讀取數(shù)據(jù)行的方式,即可夠解析含有多種格式的文字文件并順利讀取。
舉例來(lái)說(shuō),假設(shè)我們?cè)趹?yīng)用程序項(xiàng)目的Text文件夾含有一個(gè)名稱(chēng)為“多格式文本文件.txt”的文本文件,此文本文件的特殊之處在于它含有下列三種格式:
·固定字段寬度分別為5、10與 -1的數(shù)據(jù)行。
·固定字段寬度分別為6、10、17與 -1的數(shù)據(jù)行。
·采用逗號(hào)分隔的數(shù)據(jù)行。
上述這三種格式的數(shù)據(jù)行存在一個(gè)特點(diǎn),就是數(shù)據(jù)行的開(kāi)頭字符分別是CK、PB與SP,因此我們只要通過(guò)TextFieldParser對(duì)象的PeekChars方法取得數(shù)據(jù)行的前兩個(gè)字符,然后根據(jù)其值來(lái)設(shè)定TextFieldType屬性,以及設(shè)定Delimiters屬性(或調(diào)用SetDelimiters方法)或FieldWidths屬性(或調(diào)用SetFieldWidths方法),并使用ReadFields方法來(lái)讀取數(shù)據(jù)行。反復(fù)使用此方式來(lái)處理每一筆數(shù)據(jù)行,就能夠順利解析并讀取整個(gè)文本文件。
以下的程序代碼示范如何將“多格式文本文件.txt”中的三種格式數(shù)據(jù)解析出來(lái)并分別顯示于各自的DataGridView控件中。相關(guān)程序代碼列示如下:
private void CH1_DemoForm035_Load(object sender, EventArgs e)
{
txtResult.Text = File.ReadAllText(@"Text\多格式文本文件.txt");
DataGridView1.ColumnHeadersVisible = true;
// 設(shè)定欄標(biāo)題樣式。
DataGridViewCellStyle columnHeaderStyle = new DataGridViewCellStyle();
columnHeaderStyle.BackColor = Color.Beige;
columnHeaderStyle.Font = new Font("Verdana", 9, FontStyle.Bold);
DataGridView1.ColumnHeadersDefaultCellStyle = columnHeaderStyle;
// 設(shè)定 DataGridView 控件的數(shù)據(jù)行數(shù)目。
DataGridView1.ColumnCount = 3;
// 設(shè)定各數(shù)據(jù)行的標(biāo)題名稱(chēng)。
DataGridView1.Columns[0].Name = "類(lèi)別編號(hào)";
DataGridView1.Columns[1].Name = "類(lèi)別名稱(chēng)";
DataGridView1.Columns[2].Name = "說(shuō)明";
DataGridView1.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells;
DataGridView2.ColumnHeadersVisible = true;
DataGridView2.ColumnHeadersDefaultCellStyle = columnHeaderStyle;
// 設(shè)定 DataGridView 控件的數(shù)據(jù)行數(shù)目。
DataGridView2.ColumnCount = 4;
// 設(shè)定各數(shù)據(jù)行的標(biāo)題名稱(chēng)。
DataGridView2.Columns[0].Name = "產(chǎn)品編號(hào)";
DataGridView2.Columns[1].Name = "產(chǎn)品名稱(chēng)";
DataGridView2.Columns[2].Name = "單位數(shù)量";
DataGridView2.Columns[3].Name = "單價(jià)";
DataGridView2.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells;
DataGridView3.ColumnHeadersVisible = true;
DataGridView3.ColumnHeadersDefaultCellStyle = columnHeaderStyle;
// 設(shè)定 DataGridView 控件的數(shù)據(jù)行數(shù)目。
DataGridView3.ColumnCount = 3;
// 設(shè)定各數(shù)據(jù)行的標(biāo)題名稱(chēng)。
DataGridView3.Columns[0].Name = "貨運(yùn)公司編號(hào)";
DataGridView3.Columns[1].Name = "貨運(yùn)公司名稱(chēng)";
DataGridView3.Columns[2].Name = "電話";
如果您的文本文件含有多種格式,應(yīng)該使用TextFieldParser對(duì)象的PeekChars方法去取得數(shù)據(jù)行從頭算起特定數(shù)目的字符,以便藉此來(lái)判斷該數(shù)據(jù)行的格式,然后告知TextFieldParser對(duì)象該數(shù)據(jù)行的格式為何并讀取該數(shù)據(jù)行。PeekChars方法只會(huì)返回指定數(shù)目的字符而且不會(huì)前進(jìn)至下一行,通過(guò)這樣逐一判別每一筆數(shù)據(jù)行的格式并逐行讀取數(shù)據(jù)行的方式,即可夠解析含有多種格式的文字文件并順利讀取。
舉例來(lái)說(shuō),假設(shè)我們?cè)趹?yīng)用程序項(xiàng)目的Text文件夾含有一個(gè)名稱(chēng)為“多格式文本文件.txt”的文本文件,此文本文件的特殊之處在于它含有下列三種格式:
·固定字段寬度分別為5、10與 -1的數(shù)據(jù)行。
·固定字段寬度分別為6、10、17與 -1的數(shù)據(jù)行。
·采用逗號(hào)分隔的數(shù)據(jù)行。
上述這三種格式的數(shù)據(jù)行存在一個(gè)特點(diǎn),就是數(shù)據(jù)行的開(kāi)頭字符分別是CK、PB與SP,因此我們只要通過(guò)TextFieldParser對(duì)象的PeekChars方法取得數(shù)據(jù)行的前兩個(gè)字符,然后根據(jù)其值來(lái)設(shè)定TextFieldType屬性,以及設(shè)定Delimiters屬性(或調(diào)用SetDelimiters方法)或FieldWidths屬性(或調(diào)用SetFieldWidths方法),并使用ReadFields方法來(lái)讀取數(shù)據(jù)行。反復(fù)使用此方式來(lái)處理每一筆數(shù)據(jù)行,就能夠順利解析并讀取整個(gè)文本文件。
以下的程序代碼示范如何將“多格式文本文件.txt”中的三種格式數(shù)據(jù)解析出來(lái)并分別顯示于各自的DataGridView控件中。相關(guān)程序代碼列示如下:
private void CH1_DemoForm035_Load(object sender, EventArgs e)
{
txtResult.Text = File.ReadAllText(@"Text\多格式文本文件.txt");
DataGridView1.ColumnHeadersVisible = true;
// 設(shè)定欄標(biāo)題樣式。
DataGridViewCellStyle columnHeaderStyle = new DataGridViewCellStyle();
columnHeaderStyle.BackColor = Color.Beige;
columnHeaderStyle.Font = new Font("Verdana", 9, FontStyle.Bold);
DataGridView1.ColumnHeadersDefaultCellStyle = columnHeaderStyle;
// 設(shè)定 DataGridView 控件的數(shù)據(jù)行數(shù)目。
DataGridView1.ColumnCount = 3;
// 設(shè)定各數(shù)據(jù)行的標(biāo)題名稱(chēng)。
DataGridView1.Columns[0].Name = "類(lèi)別編號(hào)";
DataGridView1.Columns[1].Name = "類(lèi)別名稱(chēng)";
DataGridView1.Columns[2].Name = "說(shuō)明";
DataGridView1.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells;
DataGridView2.ColumnHeadersVisible = true;
DataGridView2.ColumnHeadersDefaultCellStyle = columnHeaderStyle;
// 設(shè)定 DataGridView 控件的數(shù)據(jù)行數(shù)目。
DataGridView2.ColumnCount = 4;
// 設(shè)定各數(shù)據(jù)行的標(biāo)題名稱(chēng)。
DataGridView2.Columns[0].Name = "產(chǎn)品編號(hào)";
DataGridView2.Columns[1].Name = "產(chǎn)品名稱(chēng)";
DataGridView2.Columns[2].Name = "單位數(shù)量";
DataGridView2.Columns[3].Name = "單價(jià)";
DataGridView2.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells;
DataGridView3.ColumnHeadersVisible = true;
DataGridView3.ColumnHeadersDefaultCellStyle = columnHeaderStyle;
// 設(shè)定 DataGridView 控件的數(shù)據(jù)行數(shù)目。
DataGridView3.ColumnCount = 3;
// 設(shè)定各數(shù)據(jù)行的標(biāo)題名稱(chēng)。
DataGridView3.Columns[0].Name = "貨運(yùn)公司編號(hào)";
DataGridView3.Columns[1].Name = "貨運(yùn)公司名稱(chēng)";
DataGridView3.Columns[2].Name = "電話";