【愛上Java8】使用POI讀取Excel表

最近有這麼一個小需求,需要從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的區別。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章