去重和排序如何操作

去重和排序是开发过程中经常碰到的问题,这篇文章就来总结一下。

去重

方法1:使用内置的distinct

代码如下:

//方法1:使用默认的distinct方法//只能针对基元类型列表,对于自定义类型组合字段条件需要自定义相等比较器实现IEqualityComparer接口,比较麻烦var result1 = list.Distinct().ToList();

登录后复制

方法2:使用GroupBy

代码如下:

//方法2:使用GroupByvar result2 = list.GroupBy(p => new { p.BunkCode, p.BunkPrice })    .Select(p => p.First())    .ToList();

登录后复制

方法3:使用自己扩展的DistinctBy方法

代码如下:

//方法3:使用自己扩展的DistinctBy方法//利用HashSet的key不能重复的特性var result3 = list.DistinctBy(p => new { p.BunkCode, p.BunkPrice })    .ToList();

登录后复制

 

完整代码请参考:

/// /// 测试类型/// public class TestDistinctClass{public int Id { get; set; }public string BunkCode { get; set; }public double BunkPrice { get; set; }}/// /// 测试去重/// private static void TestDistinct(){//数据源var list = new List     {new TestDistinctClass        {            Id= 1,            BunkCode= "A",            BunkPrice= 101},new TestDistinctClass        {            Id= 2,            BunkCode= "B",            BunkPrice= 102},new TestDistinctClass        {            Id= 3,            BunkCode= "C",            BunkPrice= 103},new TestDistinctClass        {            Id= 4,            BunkCode= "D",            BunkPrice= 104},new TestDistinctClass        {            Id= 5,            BunkCode= "A",            BunkPrice= 101}    };//方法1:使用默认的distinct方法//只能针对基元类型列表,对于自定义类型组合字段条件需要自定义相等比较器实现IEqualityComparer接口,比较麻烦var result1 = list.Distinct().ToList();//方法2:使用GroupByvar result2 = list.GroupBy(p => new { p.BunkCode, p.BunkPrice })        .Select(p => p.First())        .ToList();//方法3:使用自己扩展的DistinctBy方法//利用HashSet的key不能重复的特性var result3 = list.DistinctBy(p => new { p.BunkCode, p.BunkPrice })        .ToList();}

登录后复制

 

同时,我把扩展方法也贴出来:

/// /// 扩展distinct/// /// /// /// /// /// public static IEnumerable DistinctBy(this IEnumerable source, Func keySelector){    HashSet seenKeys = new HashSet();foreach (TSource element in source)    {if (seenKeys.Add(keySelector(element)))        {yield return element;        }    }}

登录后复制

 

排序

至于排序,使用Linq提供的api就好了,如下图:

2017-06-02_153425

以上就是去重和排序如何操作的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2439898.html

(0)
上一篇 2025年3月3日 12:14:43
下一篇 2025年2月23日 03:10:20

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论