如果我的txt文件包含与这些类似的行:
1.1, 0.1836856, 5.6
3.3, -5.5, 43.44
-0.38162, 6.636666E-08, 3.1
1.01516E-07, 0.3695395, 1.5
如何将文件读入元组?
var reader = new StreamReader(File.OpenRead(@"C:\MyFile.txt"));
while (!reader.EndOfStream)
{
var line = reader.ReadLine();
var values = line.Split(',');
var val1 = decimal.Parse(values[0], System.Globalization.NumberStyles.Float);
var val2 = decimal.Parse(values[1], System.Globalization.NumberStyles.Float);
var val3 = values[2];
Tuple<decimal, decimal, string> myTuple = Tuple.Create<decimal, decimal, string>(val1, val2, val3);
}
答案 0 :(得分:5)
你基本上就在那里..只需将每个元组添加到一个列表中,这样它们就不会在每次迭代结束时丢失。
在while
循环之外和之前定义一个List:
var results = new List<Tuple<decimal, decimal, string>>();
然后在循环中添加每个新的Tuple实例:
results.Add(Tuple.Create(val1, val2, val3));
您也可以考虑将File.OpenRead()
替换为File.ReadLines()
。它打开你的文件,读取所有行,并一次性关闭它。
这些东西看起来与你拥有的东西真的不同......只是扔掉那里。它是否更清楚取决于你。它使用LINQ。
它读取文件,然后拆分并为每一行创建Tuple
,生成相同的列表。
var results = (from line in File.ReadLines(@"C:\MyFile.txt")
let values = line.Split(',')
select Tuple.Create(decimal.Parse(values[0], NumberStyles.Float),
decimal.Parse(values[1], NumberStyles.Float),
values[2])).ToList();