方法一:使用Set

List<User> newList = new ArrayList<User>();
Set<String> set = new HashSet<String>();
for (User user : list) {
String userName = user.getName();
if (!set.contains(userName)) { //set中不包含重复的
set.add(userName);
newList.add(user);
}
} System.out.println("Set去重后的集合: " + newList);

方法二:使用Map

List<User> newList = new ArrayList<User>();

HashMap<String, String> map = new HashMap<String, String>();
for (User user : list) {
String userName = user.getName();
String value = map.get(userName);
if (StringUtils.isBlank(value)) { //如果value是空的 说明取到的这个name是第一次取到
map.put(userName, userName);
newList.add(user); //newList就是我们想要的去重之后的结果
}
} System.out.println("Map去重后的集合: " + newList);

方法三:使用List(可以根据多个字段)

List<String> newList = new ArrayList<String>();
List<User> userList = new ArrayList<User>();
for (User cd : list) {
if (!newList.contains("" + cd.getAge())) { // 多个字段的话"" + cd.getAge() + cd.getSex()
newList.add("" + cd.getAge()); // 多个字段的话"" + cd.getAge() + cd.getSex()
userList.add(cd);
}
} System.out.println("List去重后的集合: " + userList);

附:测试User类

/**
* list根据某个字段去重
*
* @author xc
* @version V1.0 2017年9月30日
*/
public class list根据某个字段去重 { private static List<User> list; static {
User user1 = new User("zhangsan1", 20, true);
User user2 = new User("zhangsan2", 20, true);
User user3 = new User("zhangsan1", 30, true);
list = new ArrayList<User>();
list.add(user1);
list.add(user2);
list.add(user3);
} public static void main(String[] args) {
duplicateMap();
duplicateSet();
duplicateList();
} /**
* 使用List
*/
private static void duplicateList() {
List<String> newList = new ArrayList<String>();
List<User> userList = new ArrayList<User>();
for (User cd : list) {
if (!newList.contains("" + cd.getAge() + cd.getSex())) {
newList.add("" + cd.getAge() + cd.getSex());
userList.add(cd);
}
} System.out.println("List去重后的集合: " + userList);
} /**
* 使用set
*/
private static void duplicateSet() {
List<User> newList = new ArrayList<User>();
Set<String> set = new HashSet<String>();
for (User user : list) {
if (user == null) {
continue;
}
String userName = user.getName();
if (userName != null) {
if (!set.contains(userName)) { //set中不包含重复的
set.add(userName);
newList.add(user);
} else {
continue;
}
}
} System.out.println("Set去重后的集合: " + newList); } /**
* 使用map
*/
private static void duplicateMap() {
List<User> newList = new ArrayList<User>(); HashMap<String, String> map = new HashMap<String, String>();
for (User user : list) {
if (user == null) {
continue;
}
String name = user.getName();
if (name != null) {
String value = map.get(name);
if (StringUtils.isBlank(value)) { //如果value是空的 说明取到的这个name是第一次取到
map.put(name, name);
newList.add(user); //newList就是我们想要的去重之后的结果
} else {
continue;
}
}
} System.out.println("Map去重后的集合: " + newList); } }

list根据某个字段去重的更多相关文章

  1. list集合中指定字段去重

    在开发中,有时会需要指定字段去重,以下为实现方法: 假设有个房地产权的类,其中宗地代码ZDDM值重复,而我们在前端页面显示时,只需要一条数据,因为公共字段都一样: IEqualityComparer需 ...

  2. MySQL 查询重复的数据,以及部分字段去重和完全去重

    1.查找表中多余的重复记录(多个字段) select * from vitae a where (a.peopleId,a.seq) in  (select peopleId,seq from vit ...

  3. sql针对某一字段去重,并且保留其他字段

    今天客户提了一个小需求,希望我能提供一条sql语句,帮助他对数据中 _field 这个字段的值去重,并且保留其他字段的数据.第一反应是select distinct,但这种语句在对某个字段去重时,无法 ...

  4. php二维数组根据某个字段去重

    php的二维数组根据某个字段去重,在这默认为二维数组的结构是一样的,现在根据二维数组里的id字段去重,把id相同的重复的元素去掉 /** * 二维数组根据某个字段去重 * @param array $ ...

  5. List集合中的对象按照某个字段去重实现

    package com.liying.banana.user; import java.util.ArrayList; import java.util.Comparator; import java ...

  6. DataTable根据字段去重

    DataTable根据字段去重 最近需要对datatable根据字段去重,在网上搜了很多,找到了一个方法,代码如下 public static DataTable DistinctSomeColumn ...

  7. oracle 多字段去重查询

      oracle 多字段去重查询 CreationTime--2018年6月29日15点11分 Author:Marydon 1.情景展示 需要对表BASE_MRI_DEVICE的COMPNAME.F ...

  8. C#NPOI.RabbitMQ.EF.Attribute.HttpRuntime.Cache.AD域.List<T>根据指定字段去重.前端JQuery.Cache.I18N(多语言).data-xx(自定义属性)

    使用NPOI 操作Excel 个人使用的电脑基本默认安装Excel 操作起来 调用Excel的组件便可.如果是一台服务器.没有安装Excel,也就无法调用Excel组件. 在此推荐第三方插件.NPOI ...

  9. 数据库表设计时一对一关系存在的必要性 数据库一对一、一对多、多对多设计 面试逻辑题3.31 sql server 查询某个表被哪些存储过程调用 DataTable根据字段去重 .Net Core Cors中间件解析 分析MySQL中哪些情况下数据库索引会失效

    数据库表设计时一对一关系存在的必要性 2017年07月24日 10:01:07 阅读数:694 在表设计过程中,我无意中觉得一对一关系觉得好没道理,直接放到一张表中不就可以了吗?真是说,网上信息什么都 ...

随机推荐

  1. [转帖]BRD、MRD 和 PRD

    来源: https://www.zhihu.com/question/19655491 BRD 商业需求文档 Business Requirement Document MRD 市场需求文档 Mark ...

  2. Swagger2常用注解及其说明 (转)

    Api 用在Controller中,标记一个Controller作为swagger的文档资源 属性名称 说明 value Controller的注解 description 对api资源的描述 hid ...

  3. 在IWMS中的分页效果

    第一步,你需要在后台修改你所要显示的新闻数目: 第二步,你需要把这段代码加到你需要分页的列表里边 代码: <%=config.TopAd%><asp:Literal id=" ...

  4. Scrapy网络爬虫框架的开发使用

    1.安装 2.使用scrapy startproject  project_name 命令创建scrapy项目 如图: 3.根据提示使用scrapy genspider spider_name dom ...

  5. jquery的show()和hide()方法

    显示和隐藏元素的方法 相当于CSS中的display属性 show()方法,相当于display:block hide()方法,相当于display:none

  6. adoquery.refresh和adoquery.query的区别

    大的区别没有 1: requery是通过重新发出原始命令并再次检索数据,可使用 Requery 方法刷新来自数据源的 Recordset 对象的全部内容.调用该方法等于相继调用 Close 和 Ope ...

  7. PDO访问Mysql数据库

    $dsn = 'mysql:host=127.0.0.1;dbname=myblog'; $username = 'root'; $pwd = '; $pdo = new PDO($dsn,$user ...

  8. react使用setstate注意的两点

    1.this.state里的属性不修改,或是只修改一个,那么不修改的剩下的属性不会被变动. this.state={ name:"Aliece", age:19, msg:&quo ...

  9. 关于读取mapper的两种方式

    第一种: 第二种:

  10. Linux命令归纳

    Linux基本命令 Linux Xshell远程连接 ssh 用户名@id地址 例如: ssh root@192.168.11.53 增加类指令 创建文件夹 mkdir 文件名 mkdir -p 路径 ...