将数据从文件加载并解析为数组

时间:2016-03-27 10:33:11

标签: c# string readfile

我正在尝试将数据从DAT文件加载到数组中。

我的数据由以下格式的多行组成:

param_1::param_2::value

我想读取这些数据并将其转换为2D数组(或其他合适的格式),所以我将:

myData[param_1,param_2]=value

目前我正在尝试使用StreamReader将文件读入一个字符串数组,但不知道如何将字符串中的数据转换为我需要的格式。

这是我正在使用的阅读部分。我需要做什么才能正确解析数据?

        StreamReader reader = new StreamReader("file.dat");
        string strAllFile = reader.ReadToEnd().Replace("\r\n", "\n").Replace("\n\r", "\n");
        string[] arrLines = strAllFile.Split(new char[] { '\n' });

感谢您的帮助!

2 个答案:

答案 0 :(得分:2)

你可以做这样的事情,这个Linq语句从文件的每一行返回param1, param2, value的集合。

var dataList = File.ReadAllLines("file.dat") // Read lines
        .Select(l=> l.Split(new string[] { "::" }, StringSplitOptions.None)) // split each line
        .Select(l=> new 
               {
                  param1 = l[0],
                  param2 = l]1],
                  value  = l[2]
               })
        .ToList(); 

现在您可以使用

迭代列表
foreach(var item in dataList)
{
    // logic here.
    myData[item.param1,item.param2]=item.value

}

答案 1 :(得分:0)

如果已知myData的行数和列数,您只需编写如下函数:

public void parseString(string[] lines)
{
    int[,] myData = new int[100, 100];
    foreach (string s in lines)
    {
        string[] data = s.Split("::");
        int x = Convert.ToInt32(data[0]);
        int y = Convert.ToInt32(data[1]);
        int value = Convert.ToInt32(data[2]);

        myData[x, y] = value;
    }
}