如何使用LinQ按值分组获取字典中的键列表

时间:2015-09-06 21:44:35

标签: c# linq dictionary group-by

好的,这是一个简单的字典

Dictionary<string,int> dicClusters=new Dictionary<string,int>();

dicClusters.Add("A",1);
dicClusters.Add("B",1);
dicClusters.Add("C",2);
dicClusters.Add("D",3);

所以我想从这个

撰写如下所示的列表
  List<List<string>> lstGroupedByKeys=dicClusters.GroupBy(pr => pr.Value)...

结果将是

first list {"A","B"}
second list {"C"}
third list {"D"}

我可以使用多个foreach或使用for循环编码它但是我相信它可以用linQ完成并且我想学习ty

c#.NET 4.5.2

1 个答案:

答案 0 :(得分:5)

GroupBy是正确的方法,但您需要另一个Select来定义每个组的表示方式:

List<List<string>> lstGroupedByKeys =
    dicClusters.GroupBy(pr => pr.Value)
               .Select(g => g.Select(pr => pr.Key).ToList())
               .ToList();

或者您可以使用不同的GroupBy重载:

List<List<string>> lstGroupedByKeys =
    dicClusters.GroupBy(pr => pr.Value, pr => pr.Key, (k, g) => g.ToList())
               .ToList();

使用基于语法的查询时可能更清晰:

var lstGroupedByKeys = (from pr in dicClusters
                        group pr.Key by pr.Value into g
                        select g.ToList()).ToList();