6

开始处理由管道下划线和管道分隔的文本文件阅读 - |_| 尝试了以下代码。没有产生预期的结果。拆分条件应该修改,但是如何修改。请指教。谢谢大家 - 现在可以了。

class Program
{
    static void Main(string[] args)
    {
        string filePath = @"J:\dot\emp.dat";


        var query = 
            from line in File.ReadLines(filePath)
            let empRecord = line.Split(new string[] {"|_|"},StringSplitOptions.None)

            select new datFile()
            {
                name = empRecord[0],
                employeeid = empRecord[1],
                income = empRecord[2],
                expenses = empRecord[3]

            };

        foreach (var item in query)
        {
            Console.WriteLine(item.name, item.employeeid, 
                 item.income, item.expenses);
        }
        Console.ReadLine();
    }

    public class datFile
    {
        public string name { get; set; }
        public string employeeid { get; set; }
        public string income { get; set; }
        public string expenses { get; set; }

      }
   }

文件内容:

name|_|employeeid|_|income|_|expenses
emp1|_|201501|_|100000|_|50000
emp2|_|20000|_|90000|_|30000
emp3|_|34234|_|100000|_|23000

输出:

 name
 emp1
 emp3
 emp3   
 ----- 
4

4 回答 4

15

问题实际上就在这里:

Console.WriteLine(item.name, item.employeeid, item.income, item.expenses);

item.name用作格式字符串,恰好不包含{0}, {1}or {2},因此其余参数实际上是无用的。试试这个,它指定一个格式字符串,然后是要填写的值:

Console.WriteLine("{0} {1} {2} {3}", 
                  item.name, item.employeeid, item.income, item.expenses);
于 2011-08-11T17:46:40.320 回答
0

我很尴尬地说我必须对此进行大量测试才能找出问题所在,但那是因为问题非常明显。

除了这一行之外,此示例中的所有内容都是正确的:

Console.WriteLine(item.name, item.employeeid, item.income, item.expenses);

尝试:

Console.WriteLine("name={0}, employeeid={1}, income={2}, expenses={3}",
   item.name, item.employeeid, item.income, item.expenses);
于 2011-08-11T17:57:35.987 回答
0

您是否尝试过使用 char[] 而不是 string[] 进行拆分?

let empRecord = line.Split(new char[] {'|', '_', '|'});
于 2011-08-11T17:49:10.323 回答
0

我不太使用控制台应用程序,但尝试按如下方式更改您的代码:

foreach (var item in query)
{
    Console.WriteLine("{0}, {1}, {2}, {3}",
        item.name, item.employeeid, item.income, item.expenses);
}
于 2011-08-11T17:49:41.550 回答