将数组拆分为2个部分

时间:2013-10-12 16:41:56

标签: c# dictionary multidimensional-array

我正在尝试以这种格式读取日志文件:

date | cost
date | cost
..ect

使用以下代码将文件读入数组:

string[] lines = File.ReadAllLines("log.txt");

我的问题是如何将数组切成每行2个部分,以便我可以将它们添加到2列的列表视图中?我想也许字典会是一个好的开始..

4 个答案:

答案 0 :(得分:1)

var lines = File.ReadAllLines("log.txt").Select(l=> l.Split('|'));
var dictionary= lines.ToDictionary(x => x[0], y => y[1]);

答案 1 :(得分:1)

假设这是C#而不是C,以下可能会做你想要的:

public class LogEntry{

    public string Date;
    public string Cost;


    public LogEntry(string date,string cost){
        Date=date;
        Cost=cost;
    }

}

...

// Grab the lines from the file:
string[] lines = File.ReadAllLines("log.txt");

// Create our output set:
LogEntry[] logEntries=new LogEntry[lines.Length];

// For each line in the file:
for(int i=0;i<lines.Length;i++){
    // Split the line:
    string[] linePieces=lines[i].Split('|');

    // Safety check - make sure this is a line we want:
    if(linePieces.Length!=2){
        // No thanks!
        continue;
    }

    // Create the entry:
    logEntries[i]=new LogEntry( linePieces[0] , linePieces[1] );
}

// Do something with logEntries.

请注意,此类处理只能使用相对较小的日志文件来完成。 File.ReadAllLines(“log.txt”)对于大文件效率非常低,此时使用原始FileStream更合适。

答案 2 :(得分:0)

使用2D数组和string.Split('-')

string[] lines = File.ReadAllLines("log.txt");
//Create an array with lines.Length rows and 2 columns
string[,] table = new string[lines.Length,2];
for (int i = 0; i < lines.Length; i++)
{
     //Split the line in 2 with the | character
     string[] parts = lines[i].Split('|');
     //Store them in the array, trimming the spaces off
     table[i,0] = parts[0].Trim();
     table[i,1] = parts[1].Trim();
}

现在你将拥有一个如下所示的数组:

table[date, cost]

您可以使用字典,这样您只需要查看日期即可。 编辑:由于@ Damith已完成

此外,使用LINQ,您可以将其简化为:

var table = File.ReadAllLines("log.txt").Select(s => s.Split('|')).ToDictionary(k => k[0].TrimEnd(' '), v => v[1].TrimStart(' '));

现在您可以使用以下命令轻松获取LINQ表达式的结果:

foreach (KeyValuePair<string, string> kv in table)
{
      Console.WriteLine("Key: " + kv.Key + " Value: " + kv.Value);
}

另请注意,如果您不需要文件中的空格,则可以省略Trim() s

答案 3 :(得分:0)

只是因为这篇帖子最初标记为 C:)
这是一个C示例:

使用如下所示的数据文件(我称之为temp.txt):

3/13/56 | 13.34
3/14/56 | 14.14
3/15/56 | 15.00
3/16/56 | 16.56
3/17/56 | 17.87
3/18/56 | 18.34
3/19/56 | 19.31
3/20/56 | 20.01
3/21/56 | 21.00  

此代码将读取它,将其解析为单个2 dim字符串数组char col[2][80][20];

#include <ansi_c.h>

int main()
{
    int i;
    char *buf;
    char line[260];
    char col[2][80][20];
   FILE *fp;
   fp = fopen("c:\\dev\\play\\temp.txt", "r");
   i=-1;
   while(fgets(line, 260, fp))
   {
        i++;
        buf = strtok(line, "|");
        if(buf) strcpy(col[0][i], buf);
        buf = strtok(NULL, "|");
        if(buf) strcpy(col[1][i], buf);
   }
   fclose(fp);

   return 0;
}