去重和排序是开发过程中经常碰到的问题,这篇文章就来总结一下。
去重
方法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就好了,如下图:
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。