C# - 如何解析文本文件(空格分隔数字)?

时间:2011-05-20 00:01:05

标签: c# .net file string string-parsing

给定由空格分隔的数据文件

10 10 10 10 222 331 
2 3 3 4 45
4 2 2 4

如何读取此文件并加载到数组

谢谢

4 个答案:

答案 0 :(得分:13)

var fileContent = File.ReadAllText(fileName);
var array = fileContent.Split((string[])null, StringSplitOptions.RemoveEmptyEntries);

如果您只有数字并且需要一个int列表,那么您可以这样做:

var numbers = array.Select(arg => int.Parse(arg)).ToList();

答案 1 :(得分:6)

这取决于你想要的数组类型。如果你想将所有东西展平成一维数组,那么请使用Alex Aza的答案,否则,如果你想要一个映射到文本文件中的行和元素的二维数组:

var array = File.ReadAllLines(filename)
                .Select(line => line.Split(" ".ToCharArray(), StringSplitOptions.RemoveEmptyEntries))
                .Where(line => !string.IsNullOrWhiteSpace(line)) // Use this to filter blank lines.
                .Select(int.Parse) // Assuming you want an int array.
                .ToArray();

请注意,没有错误处理,因此如果解析失败,上面的代码将抛出异常。

答案 2 :(得分:1)

答案 3 :(得分:0)

我无法获得Quick Joe Smith的工作答案,所以我对其进行了修改。我将修改后的代码放入" FileReader"中的静态方法中。类:

public static double[][] readWhitespaceDelimitedDoubles(string[] input)
{
    double[][] array = input.Where(line => !String.IsNullOrWhiteSpace(line)) // Use this to filter blank lines.
        .Select(line => line.Split((string[])null, StringSplitOptions.RemoveEmptyEntries))
        .Select(line => line.Select(element => double.Parse(element)))
        .Select(line => line.ToArray())
        .ToArray();

        return array;
}

对于我的应用程序,我正在解析double而不是int。要调用代码,请尝试使用以下内容:

string[] fileContents = System.IO.File.ReadAllLines(openFileDialog1.FileName);
double[][] fileContentsArray = FileReader.readWhitespaceDelimitedDoubles(fileContents);

Console.WriteLine("Number of Rows:      {0,3}", fileContentsArray.Length);
Console.WriteLine("Number of Cols:      {0,3}", fileContentsArray[0].Length);
相关问题