去重和排序如何操作

互联网 17-6-24

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

去重

方法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就好了,如下图:

以上就是去重和排序如何操作的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: 用的
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:EasyLoader(简单加载)实例

相关资讯