开始处理文本文件读取 - 由管道下划线和管道分隔 - | _ | 尝试了以下代码。但是没有产生预期的结果。 拆分条件应该修改,但如何。请指教。 谢谢大家 - 现在就可以了。
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
-----
答案 0 :(得分:15)
问题实际上就在这里:
Console.WriteLine(item.name, item.employeeid, item.income, item.expenses);
那是使用item.name
作为格式字符串,其中不包含{0}
,{1}
或{2}
,因此其余参数有效没用。试试这个,它指定一个格式字符串,然后要填写的值:
Console.WriteLine("{0} {1} {2} {3}",
item.name, item.employeeid, item.income, item.expenses);
答案 1 :(得分:0)
您是否尝试使用char []而不是string []进行拆分?
let empRecord = line.Split(new char[] {'|', '_', '|'});
答案 2 :(得分:0)
我对控制台应用程序不起作用,但尝试按如下方式更改代码:
foreach (var item in query)
{
Console.WriteLine("{0}, {1}, {2}, {3}",
item.name, item.employeeid, item.income, item.expenses);
}
答案 3 :(得分: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);