2009-05-29 111 views
0

我需要解析一個文件,但數據是一種奇怪的格式,我不熟悉解析。解析奇怪格式的文件

數據總是像這樣格式化。字段名稱位於左側,數據位於「=」右側,所有字段始終按此順序排列。

文件數據:

Report 1 of 1 
job_name = JOBNAME 
job_no = JOB99999 job_id = 6750 
rprt_id = 27811 
rprt_name = SOMEDATA.SOMEUSER.JOBNAME.JOB099999.0000000.? 
ftp_size = 999999 
job_group_name = 1 
clas = Z 
form = 9999 
user_id = SOMEUSER 

我的第一本能是做這樣的事情......

 'New up a class created to hold the data' 
     Dim NFOData As New NFOData 
     'Create counter for line numbers' 
     Dim i As Integer = 1 

     Using sr As New StreamReader(filename) 
      While Not sr.EndOfStream 
       Dim line As String = sr.ReadLine 

       Select Case i 
        Case 2 
         NFOData.JobName = line.Substring(11) 
        Case 3 
         NFOData.JobNo = line.Substring(9) 
        Case 4 
         'snipped to save space' 
       End Select 

       i += 1 
      End While 
     End Using 

這似乎不是很乾淨或優雅給我。

是否有一個更優雅的方式來處理解析這樣的文件?

+0

對我來說,它看起來像數據是在右邊,而不是在左邊。 – RedFilter 2009-05-29 00:53:35

回答

1

下面的代碼是C#,但應該輕鬆轉換爲VB。它使用字典將文件中的密鑰映射到PropertyInfo,然後使用反射設置該值。處理第一行不見了,也許還有一些小問題。

Dictionary<String, PropertyInfo> map = new Dictionary<String, PropertyInfo>(); 

map["job_name"] = typeof(NFOData).GetProperty("JobName"); 
map["job_no"] = typeof(NFOData).GetProperty("JobNo"); 
// .... 

NFOData nfoData = new NfOData(); 

using (StreamReader sr = new StreamReader(filename)) 
{ 
    String line; 

    while ((line = sr.ReadLine()) != null) 
    { 
     String[] parts = line.Split(new[] {" = "}, StringSplitOptions.None); 

     map[parts[0]].SetValue(nfoData, parts[1], null); 
    } 
} 
0

我很可能會讀取每一行,將它拆分爲=,並將其放在字符串散列中,其中字段名稱是鍵,因此您可以通過字段名引用它。

0

這是C#(對不起,我沒有VB),並具有任何類型的錯誤檢查,但如何像KeyValuePairs的名單...

using System; 
using System.Collections.Generic; 
using System.IO; 
using System.Linq; 
using System.Text; 

namespace NVP 
{ 
    class Program 
    { 
     static void Main(string[] args) 
     { 
      var nvp = new List<KeyValuePair<string, string>>(); 
      var fs = File.Open(@"c:\temp\report.txt", FileMode.Open); 

      var sw = new StreamReader(fs); 

      while (!sw.EndOfStream) 
      { 
       var line = sw.ReadLine(); 
       if (!String.IsNullOrEmpty(line) && line.Contains("=")) 
       { 
        var tmp = line.Split('='); 
        nvp.Add(new KeyValuePair<string, string>(tmp[0], tmp[1])); 
       } 
      } 

      sw.Close(); 
      fs.Close(); 

      var str = nvp.Select(kv => kv.Key + " " + kv.Value); 
      str.ToList().ForEach(Console.WriteLine); 

      Console.ReadLine(); 
     } 
    } 
}