[英]How to get list of keys in a dictionary with group by value with using LinQ
好吧,这里有个简单的字典
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
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();
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.