我正在读取一个csv文件,并将它放在这个结构中:
List<Dictionary<string, object>> l = new List<Dictionary<string, object>>();CSV文件包含:
cod_curso; name
3; language
5; math
6; physic我要做的代码是:
string path = "test.csv";
List<Dictionary<string, object>> l = new List<Dictionary<string, object>>();
using (var reader = new StreamReader(path))
{
var header = reader.ReadLine();
var keys = header.Split(";");
while (!reader.EndOfStream)
{
var line = reader.ReadLine();
var values = line.Split(';');
for (int i = 0; i < values.Length; i++)
{
Dictionary<string, object> d = new Dictionary<string, object>();
d.Add(keys[i], values[i]);
l.Add(d);
}
}
}要遍历这个结构,我使用以下方法:
foreach (var item in l)
{
foreach (var dic in item)
{
Console.WriteLine(dic.Key + " " + dic.Value);
}
}我要做的是按键选择字典的值,但它对我不起作用,方法是:
var b = l.Select(a => a["cod_curso"]);我得到的是零。
"cod_curso“是csv文件的一列,是字典中的键。
下一个图像是我在调试中得到的信息。

我怎样才能实现我想要的?或者为什么会这样?
发布于 2019-06-04 23:56:47
您希望在内部循环之外创建和添加每个字典,例如:
while (!reader.EndOfStream)
{
var line = reader.ReadLine();
var values = line.Split(';');
var d = new Dictionary<string, object>(); // New dictionary for each line
for (int i = 0; i < values.Length; i++)
{
d.Add(keys[i], values[i]);
}
l.Add(d);
}https://stackoverflow.com/questions/56452476
复制相似问题