提供者:porschev

题目:下列数据放在一个List中,当ID和Name都相同时,去掉重复数据

ID Name

1  张三
1  李三
1  小伟
1  李三 
2  李四
2  李武

------------------------------------------------------------------------------------------------------------

解决这个问题,方法很多,最开始想到的就Enumerable.Distinct方法

我们可能经常用的是Distinct<TSource>(IEnumerable<TSource>)

用它对数组这一类去重复

这里要用Distinct<TSource>(IEnumerable<TSource>, IEqualityComparer<TSource>)使用指定的 IEqualityComparer<T> 对值进行比较

一、先为数据做个实体类:User

 public class User
{
public User(int id, string name)
{
Id = id;
Name = name;
} public int Id { get; set; } public string Name { get; set; }
}

二、再自定义一个User比较类(实现IEqualityComparer<T>接口):UserComparer

 public class UserComparer : IEqualityComparer<User>
{
#region IEqualityComparer<User> 成员
public bool Equals(User x, User y)
{
if (x.Id == y.Id && x.Name == y.Name) //分别对属性进行比较
return true;
else
return false;
} public int GetHashCode(User obj)
{
return ;
}
#endregion
}

自定义一个比较类,去继承IEqualityComparer接口,做一个Distinct方法的比较器。。

Equals方法中对实体进行和你需求相关的比较操作,返回bool类型的返回值

三、最后是去重复测式类:

XXXX.Distinct(new UserComparer());进行去重复操作
  public class MainClass
{
public static void Main()
{
List<User> list = new List<User>(); //添加一些测式数据
list.Add(new User(, "张三"));
list.Add(new User(, "李三"));
list.Add(new User(, "小伟"));
list.Add(new User(, "李三"));
list.Add(new User(, "李四"));
list.Add(new User(, "李武")); var query = list.Distinct(new UserComparer()); //去重复 foreach (var item in query)
{
Console.WriteLine(item.Id + "," + item.Name); //输出Distinct之后的结果
} Console.ReadLine(); //输出结果:
// 1 , 张三
// 1 , 李三
// 1 , 小伟
// 2 , 李四
// 2 , 李武
}
}

或者直接:

 public class User:IEqualityComparer<User>
{
public User(int id, string name)
{
Id = id;
Name = name;
} public int Id { get; set; } public string Name { get; set; } public bool Equals(User x, User y)
{
if (x.Id == y.Id && x.Name == y.Name) //分别对属性进行比较
return true;
else
return false;
} public int GetHashCode(User obj)
{
return ;
}
}
public class MainClass
{
public static void Main()
{
List<User> list = new List<User>(); //添加一些测式数据
list.Add(new User(, "张三"));
list.Add(new User(, "李三"));
list.Add(new User(, "小伟"));
list.Add(new User(, "李三"));
list.Add(new User(, "李四"));
list.Add(new User(, "李武")); var query = list.Distinct(new User()); //去重复 foreach (var item in query)
{
Console.WriteLine(item.Id + "," + item.Name); //输出Distinct之后的结果
} Console.ReadLine(); //输出结果:
// 1 , 张三
// 1 , 李三
// 1 , 小伟
// 2 , 李四
// 2 , 李武
}
}

用泛型的IEqualityComparer<T>接口去重复项的更多相关文章

  1. [2012-05-31]awk去重复项

    参考http://bbs.chinaunix.net/thread-2309494-1-1.html 10.awk '! a[$0]++' 怎么理解? 这是一个非常经典的去重复项的awk语句,虽然短小 ...

  2. VBA RemoveDuplicates方法去重复项

    RemoveDuplicates后边必须跟参数否则不起作用 ActiveSheet.Range("G21:R36").RemoveDuplicates Columns:=12, H ...

  3. 为了去重复,写了一个通用的比较容器类,可以用在需要比较的地方,且支持Lamda表达式

    为了去重复,写了一个通用的比较容器类,可以用在需要比较的地方,且支持Lamda表达式,代码如下: public class DataComparer<T>:IEqualityCompare ...

  4. 利用Linq对集合元素合并、去重复处理

    本文转载:http://www.cnblogs.com/yjmyzz/archive/2012/12/18/2823170.html 今天写代码时,需要对一个数组对象中按一定规则合并.去重处理,不想再 ...

  5. ASP.Net【如何合并DataTable,并且去重复方法】

    虽然DataTable.Merge可以很好的实现,但以下代码写出来更好理解 DataTable DataTable1 = new DataTable(); DataTable DataTable2 = ...

  6. 如何求ArrayList集合的交集 并集 差集 去重复并集

    需要用到List接口中定义的几个方法: addAll(Collection<? extends E> c) :按指定集合的Iterator返回的顺序将指定集合中的所有元素追加到此列表的末尾 ...

  7. 泛型(Generic)接口

    泛型接口例子:一个学生有一个独一无二的ID,但是每个学生的姓名不一定是唯一的. class Program { static void Main(string[] args) { Student< ...

  8. mysql数据库去重复

    参考:http://www.cnblogs.com/duanjie/archive/2011/08/13/2136862.html 说到去重复,感觉逻辑很简单.但动手写起来却并不是那么容易.面试的时候 ...

  9. 关系数据库SQL之高级数据查询:去重复、组合查询、连接查询、虚拟表

    前言 接上一篇关系数据库SQL之基本数据查询:子查询.分组查询.模糊查询,主要是关系型数据库基本数据查询.包括子查询.分组查询.聚合函数查询.模糊查询,本文是介绍一下关系型数据库几种高级数据查询SQL ...

随机推荐

  1. .net中的多线程

    一.多线程的概念        什么是进程呢?当一个程序开始运行时,它就是一个进程,进程所指包括运行中的程序和程序所使用到的内存和系统资源.而一个进程又是由多个线程所组成的,线程是程序中的一个执行流, ...

  2. 完整HttpHelper类

    [代码] [C#]代码 using System; using System.Collections.Generic; using System.Text; using System.Net; usi ...

  3. ProgressBar的Indeterminate属性

    Indeterminate ProgressBar默认是白色的,如果容器的背景也是白色的,这样就根本看不到Progressbar. 简单解决方案: 用style属性设定反转的颜色. <Progr ...

  4. mysql表的创建和删除

    在创建数据库表时,最好是在编辑器中写好创建表的代码,然后粘贴到命令行中,这样如果有错修改起来方便. 现在来创建一个user表: -- 打开数据库, --后面必须要有空格, 表示注释 USE mydb3 ...

  5. ajax中的setRequestHeader设置请求头

    1.问题引发点: 前不久发现一个问题: 前端并没有设置请求头信息里面的Accept-Encoding:gzip...但是在请求头中可以明显的看到Accept-Encoding:gzip, deflat ...

  6. [转]div内容底部对齐

    本文转自:http://blog.csdn.net/hellomy/article/details/5889833 <html> <head> <meta http-eq ...

  7. java中的CountDownLatch

    闭锁是一种同步工具类,可以延迟线程的进度直到其达到终止状态.闭锁的作用相当于一扇门:在闭锁到达结束状态值钱,这扇门一直是关闭的,没有任何线程可以通过,当到大结束状态时,这扇门会打开并允许所有的线程通过 ...

  8. duplicate symbol _OBJC_METACLASS_$ 报错记录

    duplicate symbol _OBJC_METACLASS_$_TabbarButton in: /Users/hw201406/Library/Developer/Xcode/DerivedD ...

  9. Discuz!图片查看插件(支持鼠标缩放、实际大小、旋转、下载)

    Discuz!图片查看插件(支持鼠标缩放.实际大小.旋转.下载) 图片查看是网站中的常用功能,用于展示详细的图片.在discuz图片插件的基础上进行了改造,因此这篇文章主要从以下几个方面来讨论图片查看 ...

  10. freeCodeCamp:Search and Replace

    使用给定的参数对句子执行一次查找和替换,然后返回新句子. 第一个参数是将要对其执行查找和替换的句子. 第二个参数是将被替换掉的单词(替换前的单词). 第三个参数用于替换第二个参数(替换后的单词). 注 ...