去重和排序是開發過程中常碰到的問題,這篇文章就來總結一下。
方法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(); }</testdistinctclass>
##同時,我把擴充方法也貼出來:
/// <summary>/// 扩展distinct/// </summary>/// <typeparam></typeparam>/// <typeparam></typeparam>/// <param>/// <param>/// <returns></returns>public static IEnumerable<tsource> DistinctBy<tsource>(this IEnumerable<tsource> source, Func<tsource> keySelector) { HashSet<tkey> seenKeys = new HashSet<tkey>();foreach (TSource element in source) {if (seenKeys.Add(keySelector(element))) {yield return element; } } }</tkey></tkey></tsource></tsource></tsource></tsource>
#至於排序,使用Linq提供的api就好了,如下圖:
以上是去重和排序如何操作的詳細內容。更多資訊請關注PHP中文網其他相關文章!