好的,这是一个简单的字典
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
答案 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();