• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

去重和排序如何操作

c# 搞代码 4年前 (2022-01-09) 9次浏览 已收录 0个评论
文章目录[隐藏]

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

本文来源gao.dai.ma.com搞@代*码#网

方法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();

完整代码请参考:

/// <summary>/// 测试类型/// </summary>public class TestDistinctClass{public int Id { get; set; }public string BunkCode { get; set; }public double BunkPrice { get; set; }}/// <summary>/// 测试去重/// </summary>private static void TestDistinct(){//数据源var list = new List<TestDistinctClass>     {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();}

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

/// <summary>/// 扩展distinct/// </summary>/// <typeparam name="TSource"></typeparam>/// <typeparam name="TKey"></typeparam>/// <param name="source"></param>/// <param name="keySelector"></param>/// <returns></returns>public static IEnumerable<TSource> DistinctBy<TSource, TKey>(this IEnumerable<TSource> source, Func<TSource, TKey> keySelector){    HashSet<TKey> seenKeys = new HashSet<TKey>();foreach (TSource element in source)    {if (seenKeys.Add(keySelector(element)))        {yield return element;        }    }}

排序

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

以上就是去重和排序如何操作的详细内容,更多请关注搞代码gaodaima其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:去重和排序如何操作

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址