您好,欢迎访问一九零五行业门户网

.NET框架-集合和LINQ中的“分组”技术代码详解

我们经常在一个内存集合,比如list,根据某个或某些个属性分组,统计显示。最容易想到的方法便是,根据某个关键属性,对list实例遍历,转化为如下字典类型
dictionary<string, list<myobject>
举例,已知cars,
list<car> cars = new list<car>(){ new car(1,"audia6","private"), new car(2,"futon","merchant"), new car(3,"feiren","bike"), new car(4,"bukon","private"), new car(5,"baoma","private"), new car(6,"dayun","merchant") };
想以id为键,值为car转化为一个字典idcardict,除了遍历这种逻辑最复杂,代码需要最多的方法,我们还可以直接利用todictionary方法,
ar idcardict = cars.todictionary(car=>car.id);
但是,这个方法是有局限的,关键码对应的对象实例只能有一个,也就是返回的类型为,
dictionary<string,object>
这是糟糕的,因为可能一个关键码对应多个实例,此时就得借助groupby,先按关键码分组后,然后再转化为字典。
比如,我们想以type为键,得到这个车型下的多台汽车,
dictionary<string, list<car>> typecardict = cars.groupby(car => car.type). todictionary(g => g.key, g => g.tolist());
这种转化代码简洁,比以下遍历逻辑好很多!
var dict = new dictionary<string,list<car>>();foreach(var car in cars) { if(dict.contains(car.type)) dict[car.type].add(car); else dict.add(car.type,new list<car>(){car}));}
这样解决了一个关键码对应多个实例的转化,那么根据多个关键码的组合对应多个实例的问题,借助list上的groupby能实现吗? 不能实现。
这时候,需要写linq语句,将多个关键码组合为一个新的对象,
new {key1, key2, ...}
举一个列子,我们有这么一个集合,集合中的元素是valpair对象,这个对象包含两个整形元素,val1是小者,val2相对大些。如何按照val1,val2的组合分组呢?
请看下面逻辑:
static void printfduplicatecompare(list<valpair> compares) { //按组合键分组后,每组元素个数大于2的分组,按降序排序 var rtnbyval1 = from item in compares group item by new { item.val1, item.val2 } into g where g.count()>1 orderby g.count() descending select g; //按val1和val2组合为字典键,元素个数为值 var dict = rtnbyval1.todictionary(g => g.key,g=>g.count()); }
总结
list的groupby只能根据一个键分组,如果需要根据多个键组合分组,就得写linq语句组合。
以上就是.net框架-集合和linq中的“分组”技术代码详解的详细内容。
其它类似信息

推荐信息