Java 操作 Excel (讀取Excel2007,Poi實現)

關於Java讀取Excel2007的文章在Google、百度上搜索一下,沒有太好的例子,實現的也不算太好。查看了一下Poi,最新的 POI 3.5 beta 4 支持讀寫 Excel2007和PPT2007(XLSX and PPTX),自己來實現Java讀取Excel2007了。

 

1,下載 POI 3.5 beta 4 解壓,把其中的jar包導入項目文件。以我的讀取爲例,導入了以下jar包。


 沒有配置 log4j,測試時報告警報信息,應該爲加載順序導致的初始化問題造成(暫時沒有找原因)。

 

2,建立讀取 Excel2007 方法

 

 

Java代碼 複製代碼
  1. // 構造 XSSFWorkbook 對象,strPath 傳入文件路徑   
  2. XSSFWorkbook xwb = new XSSFWorkbook(strPath);   
  3. // 讀取第一章表格內容   
  4. XSSFSheet sheet = xwb.getSheetAt(0);   
  5. // 定義 row、cell   
  6. XSSFRow row;   
  7. String cell;   
  8. // 循環輸出表格中的內容   
  9. for (int i = sheet.getFirstRowNum(); i < sheet.getPhysicalNumberOfRows(); i++) {   
  10.     row = sheet.getRow(i);   
  11.     for (int j = row.getFirstCellNum(); j < row.getPhysicalNumberOfCells(); j++) {   
  12.         // 通過 row.getCell(j).toString() 獲取單元格內容,   
  13.         cell = row.getCell(j).toString();   
  14.         System.out.print(cell + "/t");   
  15.     }   
  16.     System.out.println("");   
  17. }  
        // 構造 XSSFWorkbook 對象,strPath 傳入文件路徑
        XSSFWorkbook xwb = new XSSFWorkbook(strPath);
        // 讀取第一章表格內容
        XSSFSheet sheet = xwb.getSheetAt(0);
        // 定義 row、cell
        XSSFRow row;
        String cell;
        // 循環輸出表格中的內容
        for (int i = sheet.getFirstRowNum(); i < sheet.getPhysicalNumberOfRows(); i++) {
            row = sheet.getRow(i);
            for (int j = row.getFirstCellNum(); j < row.getPhysicalNumberOfCells(); j++) {
                // 通過 row.getCell(j).toString() 獲取單元格內容,
                cell = row.getCell(j).toString();
                System.out.print(cell + "/t");
            }
            System.out.println("");
        }

 

 

此過程直接傳入文件所在路徑,其他一些過程已經被自動實現。

 

3,測試,文件爲8列3563行數據,以文本方式讀取內容,

 

 

Java代碼 複製代碼
  1. public static void main(String[] args) {   
  2.     SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss:SS");   
  3.     TimeZone t = sdf.getTimeZone();   
  4.     t.setRawOffset(0);   
  5.     sdf.setTimeZone(t);   
  6.     Long startTime = System.currentTimeMillis();   
  7.     String fileName = "F://我的文檔//學生繳費代碼.xlsx";   
  8.     // 檢測代碼   
  9.     try {   
  10.         PoiReadExcel er = new PoiReadExcel();   
  11.         // 讀取excel2007   
  12.         er.testPoiExcel2007(fileName);   
  13.     } catch (Exception ex) {   
  14.         Logger.getLogger(FastexcelReadExcel.class.getName()).log(Level.SEVERE, null, ex);   
  15.     }   
  16.     Long endTime = System.currentTimeMillis();   
  17.     System.out.println("用時:" + sdf.format(new Date(endTime - startTime)));   
  18. }  
    public static void main(String[] args) {
        SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss:SS");
        TimeZone t = sdf.getTimeZone();
        t.setRawOffset(0);
        sdf.setTimeZone(t);
        Long startTime = System.currentTimeMillis();
        String fileName = "F://我的文檔//學生繳費代碼.xlsx";
        // 檢測代碼
        try {
            PoiReadExcel er = new PoiReadExcel();
            // 讀取excel2007
            er.testPoiExcel2007(fileName);
        } catch (Exception ex) {
            Logger.getLogger(FastexcelReadExcel.class.getName()).log(Level.SEVERE, null, ex);
        }
        Long endTime = System.currentTimeMillis();
        System.out.println("用時:" + sdf.format(new Date(endTime - startTime)));
    }

 

 

讀取所用時間爲:4.172秒。

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