【爱上Java8】使用POI读取Excel表
2024-07-24 04:28:16 220人阅读
最近有这么一个小需求,需要从Excel里读取2张表。如果是表1和表2,那么比较表1,表2,列出在表1中存在,但是表2中不存在的项,以及在表2中存在,在表1中不存在的项。使用POI可以很轻松的完成这个功能。
首先,为表建模,表项为:
部门代码 部门名称 职位名称 职员代码 职员姓名
每一行为一个职员的信息。使用职员代码来标示每一行。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
| package zhoukai;
import org.apache.poi.ss.usermodel.Row;
public class Employee { //部门代码 部门名称 职位名称 职员代码 职员姓名
private String departId; private String departName; private String position; private String userid; private String username; //省略 setter getter public static Employee fromRow(Row r){ Employee e=new Employee(); e.setDepartId(r.getCell(0).toString()); e.setDepartName(r.getCell(1).toString()); e.setPosition(r.getCell(2).toString()); e.setUserid(r.getCell(3).toString()); e.setUsername(r.getCell(4).toString()); return e; } @Override public String toString() { return "Employee [departId=" + departId + ", departName=" + departName + ", position=" + position + ", userid=" + userid + ", username=" + username + "]"; } } |
接着,就是从Excel里读取数据了。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
| package zhoukai;
import java.io.FileInputStream; import java.io.InputStream; import java.util.HashMap; import java.util.Map;
import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.ss.usermodel.WorkbookFactory;
public class FindPeaple { //使用POI读入excel工作簿文件 public static HashMap<String,Employee> readWorkBook(int sheetid) throws Exception { // poi读取excel //创建要读入的文件的输入流 HashMap<String,Employee> map=new HashMap<String,Employee>(); InputStream inp = new FileInputStream("D:\\download\\1539.xls"); //根据上述创建的输入流 创建工作簿对象 Workbook wb = WorkbookFactory.create(inp); //得到第一页 sheet //页Sheet是从0开始索引的 Sheet sheet = wb.getSheetAt(sheetid); //利用foreach循环 遍历sheet中的所有行 for (Row row : sheet) { //遍历row中的所有方格 Employee e=Employee.fromRow(row); map.put(e.getUserid(), e); } //关闭输入流 inp.close(); return map; } public static void main(String args[]) throws Exception{ HashMap<String,Employee> _1=readWorkBook(0); HashMap<String,Employee> _2=readWorkBook(1); System.out.println("在表1,但是不在表2:"); for(String key:_1.keySet() ){ if(_2.get(key)==null){ System.out.println(_1.get(key)); } } System.out.println("在表2,但是不在表1:"); for(String key:_2.keySet() ){ if(_1.get(key)==null){ System.out.println(_2.get(key)); } } } } |
到此,就可以得到两个sheet的区别。
【爱上Java8】使用POI读取Excel表
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉:
投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。