list根据某个字段去重
方法一:使用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根据某个字段去重的更多相关文章
- list集合中指定字段去重
在开发中,有时会需要指定字段去重,以下为实现方法: 假设有个房地产权的类,其中宗地代码ZDDM值重复,而我们在前端页面显示时,只需要一条数据,因为公共字段都一样: IEqualityComparer需 ...
- MySQL 查询重复的数据,以及部分字段去重和完全去重
1.查找表中多余的重复记录(多个字段) select * from vitae a where (a.peopleId,a.seq) in (select peopleId,seq from vit ...
- sql针对某一字段去重,并且保留其他字段
今天客户提了一个小需求,希望我能提供一条sql语句,帮助他对数据中 _field 这个字段的值去重,并且保留其他字段的数据.第一反应是select distinct,但这种语句在对某个字段去重时,无法 ...
- php二维数组根据某个字段去重
php的二维数组根据某个字段去重,在这默认为二维数组的结构是一样的,现在根据二维数组里的id字段去重,把id相同的重复的元素去掉 /** * 二维数组根据某个字段去重 * @param array $ ...
- List集合中的对象按照某个字段去重实现
package com.liying.banana.user; import java.util.ArrayList; import java.util.Comparator; import java ...
- DataTable根据字段去重
DataTable根据字段去重 最近需要对datatable根据字段去重,在网上搜了很多,找到了一个方法,代码如下 public static DataTable DistinctSomeColumn ...
- oracle 多字段去重查询
oracle 多字段去重查询 CreationTime--2018年6月29日15点11分 Author:Marydon 1.情景展示 需要对表BASE_MRI_DEVICE的COMPNAME.F ...
- C#NPOI.RabbitMQ.EF.Attribute.HttpRuntime.Cache.AD域.List<T>根据指定字段去重.前端JQuery.Cache.I18N(多语言).data-xx(自定义属性)
使用NPOI 操作Excel 个人使用的电脑基本默认安装Excel 操作起来 调用Excel的组件便可.如果是一台服务器.没有安装Excel,也就无法调用Excel组件. 在此推荐第三方插件.NPOI ...
- 数据库表设计时一对一关系存在的必要性 数据库一对一、一对多、多对多设计 面试逻辑题3.31 sql server 查询某个表被哪些存储过程调用 DataTable根据字段去重 .Net Core Cors中间件解析 分析MySQL中哪些情况下数据库索引会失效
数据库表设计时一对一关系存在的必要性 2017年07月24日 10:01:07 阅读数:694 在表设计过程中,我无意中觉得一对一关系觉得好没道理,直接放到一张表中不就可以了吗?真是说,网上信息什么都 ...
随机推荐
- [转帖]SAP一句话入门:Project System
SAP一句话入门:Project System http://blog.vsharing.com/MilesForce/A621279.html 这是SAP ERP入门的最后一篇了. 我们这些死跑龙套 ...
- [转帖]ipvsadm命令参考及其应用例子
ipvsadm命令参考及其应用例子 https://blog.csdn.net/orichisonic/article/details/47375227 只是简单创建了 service和添加serve ...
- SQLSERVER sa 用户密码修改的方法
本次驱动人生病毒的收获 . 偷懒总会有报应. . 应用(数据库或者是web应用nginx等.)都不要使用最高级别权限用户来使用 虽然这样的环境问题最少. . 密码还是需要定期更换的,虽然有成本,但是也 ...
- [转帖]PAT 计算机程序设计能力考试
PAT 计算机程序设计能力考试 https://blog.csdn.net/bat67/article/details/52134211 [官方简介] 计算机程序设计能力考试(Programming ...
- Appscanner实验还原code3
# Author: Baozi #-*- codeing:utf-8 -*- import _pickle as pickle from sklearn import ensemble import ...
- python数据结构与算法第九天【选择排序】
1.选择排序的原理 2.代码实现 def selection_sort(alist): n = len(alist) # 需要进行n-1次选择操作 for i in range(n-1): # 记录最 ...
- 老男孩python学习自修第九天【yield生成器】
1.如果在一个方法中有yield关键字则该方法返回的是一个生成器对象 2.对生成器对象进行操作必须进行迭代或循环处理 例如: yield_test.py #!/usr/bin/env python # ...
- JavaScript控制阻止表单提交
1.在表单上使用onSubmit方法 <?php $form = ActiveForm::begin([ 'options'=>[ 'class' => 'form-horizont ...
- 【.NET】.NET MVC4 微信扫一扫功能实现-附全部代码
写在前面的 首先在调用微信的JS-SDK接口的时候需要仔细阅读一下官方的注意事项,否则可能事倍功半.这里先大概概述一下主要的流程,首先,使用微信扫一扫需要一个已经通过认证的公众号:其次,需要知道 ...
- SQL Server 数据库try catch 存储过程
SQL Server 在生产环境中这样写存储过程的坑都避免了吗? 原文链接: http://www.cnblogs.com/chenmh/p/7856777.html 概述 最近因为业务的需求写了一段 ...