去重和排序如何操作
时间:2017-06-24 09:44
去重和排序是开发过程中经常碰到的问题,这篇文章就来总结一下。 方法1:使用内置的distinct 代码如下: 方法2:使用GroupBy 代码如下: 方法3:使用自己扩展的DistinctBy方法 代码如下: 完整代码请参考: 同时,我把扩展方法也贴出来: 至于排序,使用Linq提供的api就好了,如下图: 以上就是去重和排序如何操作的详细内容,更多请关注gxlsystem.com其它相关文章!去重
//方法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>/// 测试类型/// </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;
}
}
}
排序