java如何读取Excel并存入list中时去除重复记录

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java如何读取Excel并存入list中时去除重复记录相关的知识,希望对你有一定的参考价值。

你做下判断就好了, 你取出一个list然后循环这个list,每一条数据肯定有个字段会有个相同,然后你判断一下,如果不相同就把这条记录放到你新new 的一个list中,如果相同就是重复了,不做处理,继续循环就好了,得到的这个新的list就是你想要的不重复的list的了 参考技术A import java.io.*;
import java.text.SimpleDateFormat;
import java.util.*;
import java.sql.*;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import jxl.*;
public class SimUpdate
private String fileName;
public SimUpdate(String fileName)
this.fileName = fileName;

static Map tNames;
static
tNames = new HashMap();

//下面是主要代码

private void updateDb()
try
Connection conn = DbPool.connectDB();
if(conn != null)
Statement stmt = conn.createStatement();
/**********************************************/
jxl.Workbook rwb = null;
try
//构建Workbook对象 只读Workbook对象
//直接从本地文件创建Workbook
//从输入流创建Workbook
InputStream is = new FileInputStream(fileName);
rwb = Workbook.getWorkbook(is);
//Sheet(术语:工作表)就是Excel表格左下角的Sheet1,Sheet2,Sheet3但在程序中
//Sheet的下标是从0开始的
//获取第一张Sheet表
Sheet rs = rwb.getSheet(0);
//获取Sheet表中所包含的总列数
int rsColumns = rs.getColumns();
//获取Sheet表中所包含的总行数
int rsRows = rs.getRows();
//获取指这下单元格的对象引用

List<Object[][]> list=new ArrayList<Object[][]>();
for(int i=0;i<rsRows;i++)
for(int j=0;j<rsColumns;j++)

Cell cell = rs.getCell(j,i);
list[i][j]= cell.getContents();



本回答被提问者采纳

Java中如何去除List中的重复的值

直接放入set中。如果List的泛型是基本类型(封装类)或String,可以直接这样做。但是泛型是你自己写的类,就需要你把这个类重写equals和hashCode方法。

import java.util.ArrayList;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Set;
 
public class Test 
 
    public static void main(String[] args) 
        /**
         * 初始化一个 ArrayList 对象,其元素有重复的值。
         */
        List<String> list = new ArrayList<String>();
        list.add("a");
        list.add("b");
        list.add("a");
        list.add("c");
        list.add("d");
        System.out.println("list = " + list.toString());
        /**
         * 利用 LinkedHashSet 的特性(按照存入顺序保存,并保证元素不重复)。
         * 将 list 传入 LinkedHashSet 的构造器中去掉重复元素
         */
        Set<String> linkedHashSet = new LinkedHashSet<String>(list);
        System.out.println("linkedHashSet = " + linkedHashSet.toString());
 
        /**
         * 将 linkedHashSet 转成 ArrayList 。
         */
        list = new ArrayList<String>(linkedHashSet);
        System.out.println("去重复后的 list = " + list);
        System.out.println("需要注意的是,如果 List 的泛型类型是自定义类型,例如Person..等,需要重写 Person 类的 equals 和 hashCode 方法。");
    

效果:

参考技术A import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

import javax.activity.ActivityRequiredException;

public class ArrayListTest 
public static void main(String[] args) 
/**
 * 定义功能:清除ArrayList集合中的重复元素
 */
List arraylist = new ArrayList();
arraylist.add("test1");
arraylist.add("test2");
arraylist.add("test3");
arraylist.add("test1");
arraylist.add("test2");
arraylist.add("test1");

System.out.println(arraylist);
singleElement(arraylist);
System.out.println(arraylist);


public static void singleElement(List arraylist) 
/**
 * 下面的size是在发生改变的,所以这样每次删除一次的时候都会影响到结果,有些结果是遍历不到的。
 */
for (int i = 0; i < arraylist.size() - 1; i++) 
Object object_x = arraylist.get(i);
for (int j = i + 1; j < arraylist.size(); j++) 
if (object_x.equals(arraylist.get(j))) 
arraylist.remove(j);
j--;// 这里是让删掉相同元素后角标返回继续比较这个位置,不然会遗漏。





/**
 * 去除重复元素的新思路:
 * 1.最后唯一性的元素也很多,先定义一个容器,用于存储这些唯一性的元素
 * 2.对原有容器进行元素的获取,冰岛临时容器中去判断本身是否存在,容器本身就有这个功能
 * 3.存在就不存储了,不存在就不存储
 * 4.遍历完原来的容器后,临时容器中存储的就是唯一性的元素。
 */
public static void singleElementNew(List list)
//定义一个临时容器
List tempArraylist=new ArrayList();

//遍历原来的容器
for (Iterator iterator = tempArraylist.iterator(); iterator.hasNext();) 
Object object = (Object) iterator.next();

//3.在临时容器中判断遍历到的元素是否存在
if (!tempArraylist.contains(object)) 

//4.如果不存在,就存储到临时容器中
tempArraylist.add(object);




//5.将原来的容器清空
list.clear();
//6.将临时容器中的元素都存储到原来的容器中
list.addAll(tempArraylist);

参考技术B Set最大的特性就是不允许在其中存放的元素是重复的
把List中的值放到 Set中,然后再从Set中取出放入List。望采纳!

以上是关于java如何读取Excel并存入list中时去除重复记录的主要内容,如果未能解决你的问题,请参考以下文章

Java读取excel文件,并存入MySQL数据库

Java中如何去除List中的重复的值

Java中如何去除List中的重复的值

JAVA中的List里的Map 如何去除重复的Key?

JAVA 将数据以EXCEL的形式存到本地

Java 读取Excel 文件存放到MySQL 数据库中,读取Excel 文件方法封装好的。用