首页
学习
活动
专区
圈层
工具
发布

LINQ
EN

Stack Overflow用户
提问于 2019-06-04 23:19:54
回答 1查看 331关注 0票数 0

我正在读取一个csv文件,并将它放在这个结构中:

代码语言:javascript
复制
List<Dictionary<string, object>> l = new List<Dictionary<string, object>>();

CSV文件包含:

代码语言:javascript
复制
cod_curso; name
3; language
5; math
6; physic

我要做的代码是:

代码语言:javascript
复制
    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);
            }
        }
    }

要遍历这个结构,我使用以下方法:

代码语言:javascript
复制
foreach (var item in l)
{
   foreach (var dic in item)
   {
      Console.WriteLine(dic.Key + " " + dic.Value);
   }
}

我要做的是按键选择字典的值,但它对我不起作用,方法是:

代码语言:javascript
复制
var b = l.Select(a => a["cod_curso"]);

我得到的是零。

"cod_curso“是csv文件的一列,是字典中的键。

下一个图像是我在调试中得到的信息。

我怎样才能实现我想要的?或者为什么会这样?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-06-04 23:56:47

您希望在内部循环之外创建和添加每个字典,例如:

代码语言:javascript
复制
    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);
    }
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56452476

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档