【发布时间】:2013-03-01 22:49:07
【问题描述】:
我有一个文本文件,其中包含我要解析的固定长度表。但是,文件的开头是有关何时生成此表的一般信息(IE 时间、数据等)。
要阅读此内容,我尝试创建一个FileStream,然后使用StreamReader 阅读此文件的第一部分。我从文档的顶部解析出我需要的内容,然后当我完成后,将流的位置设置为结构化数据的第一行。
然后我将TextFieldParser 附加到流中(使用固定长度表的适当设置),然后尝试读取文件。在第一行,它失败了,在ErrorLine 属性中,它列出了表格第三行的后半部分。我浏览了它,它位于要阅读的第一行,但ErrorLine 属性却暗示了其他情况。
调试时,我发现如果在将TextFieldParser 附加到流后尝试使用StreamReader.ReadLine() 方法,前2 行显示正常。但是,当我阅读第三行时,它会返回一行,它从第三行的前半部分开始(并在ErrorLine 中的文本所在的位置停止)附加了文档后面的一些部分。如果我在附加 TextFieldParser 之前尝试此操作,它会读取所有 3 行。
我感觉这与我将 2 个读者绑定到同一个流有关。我不知道如何用结构化部分和非结构化部分来阅读这个,而不仅仅是自己标记这些行。我可以这样做,但我认为我不是第一个想以一种方式读取流的一部分,而以另一种方式读取流的后半部分的人。
为什么会这样跳过,你将如何读取不同格式的文本文件?
例子:
Date: 3/1/2013
Time: 3:00 PM
Sensor: Awesome Thing
Seconds X Y Value
0 5.1 2.8 55
30 4.9 2.5 33
60 5.0 5.3 44
为此简化示例量身定制的代码:
Boolean setupInfo = true;
DataTable result = new DataTable();
String[] fields;
Double[] dFields;
FileStream stream = File.Open(filePath,FileMode.Open);
StreamReader reader = new StreamReader(stream);
String tempLine;
for(int j = 1; j <= 7; j++)
{
result.Columns.Add(("Column" + j));
}
//Parse the unstructured part
while(setupInfo)
{
tempLine = reader.ReadLine();
if( tempLine.StartsWith("Date: "))
{
result.Rows.Add(tempLine);
}
else if (tempLine.StartsWith("Time: "))
{
result.Rows.Add(tempLine);
}
else if (tempLine.StartsWith("Seconds")
{
//break out of this loop because the
//next line to be read is the unstructured part
setupInfo = false;
}
}
//Parse the structured part
TextFieldParser parser = new TextFieldParser(stream);
parser.TextFieldType = FieldType.FixedWidth;
parser.HasFieldsEnclosedInQuotes = false;
parser.SetFieldWidths(10, 10, 10, 10);
while (!parser.EndOfData)
{
if (reader.Peek() == '*')
{
break;
}
else
{
fields = parser.ReadFields();
if (parseStrings(fields, out dFields))
{
result.Rows.Add(dFields);
}
}
}
return result;
【问题讨论】:
-
你能发布你的代码吗?这将有助于识别问题
-
@VladL 好的,我添加了为此示例量身定制的代码。需要注意的一点是,我将数据添加到
DataTable并从该函数返回。
标签: c# stream filestream streamreader fixed-width