如何:打开双空格分隔的文件&;跳过第一行

本文关键字:一行 amp 空格 文件 分隔 如何 | 更新日期: 2023-09-27 18:26:33

这对你来说可能是一个非常简单的问题,但我被难住了。我正在尝试读取以双空格作为分隔符的文本文件。

"ColHdr1"  "ColHdr2"  "ColHdr3"  "ColHdr4"  "ColHDR5"
"fu"  "bar"  1  2  3
"lorem"  "ipsum"  5  6  7

我想把除标题行以外的所有行都放进一个列表中。这是我目前拥有的代码:

string prnFile = @"c:'temp'test.prn";
var fileLines = new List<string>();
foreach (var line in File.ReadAllLines(prnFile, Encoding.GetEncoding(1250)).Skip(1))
{
    fileLines.Add(line.Split(new[] { "  " }, 
                StringSplitOptions.RemoveEmptyEntries));
}

最后,我希望列表看起来像:

"fu"  "bar"  1  2  3
"lorem"  "ipsum"  5  6  7

知道我做错了什么吗?

如何:打开双空格分隔的文件&;跳过第一行

您的代码乍一看还可以,但我会一直使用LINQ:

var lines = File.ReadLines(prnFile, Encoding.GetEncoding(1250))
                .Skip(1)
                .Select(line => line.Split(new[] { "  " }, 
                                          StringSplitOptions.RemoveEmptyEntries))
                .ToList();

这会给你一个List<string[]>。这似乎对我有用,但请注意,它不会从字符串的开始/结束处去掉双引号。

如果你真的想要一个扁平的列表,这非常容易——只需将Select更改为SelectMany:

var lines = File.ReadLines(prnFile, Encoding.GetEncoding(1250))
                .Skip(1)
                .SelectMany(line => line.Split(new[] { "  " }, 
                                          StringSplitOptions.RemoveEmptyEntries))
                .ToList();

这给了你:

"fu"
"bar"
1
2
3
"lorem"
"ipsum"
5
6
7