Java讀取Excel內容

這裏使用的是maven項目,在pom裏面添加依賴

    <!-- xls解析 -->
    <dependency>
       <groupId>org.apache.poi</groupId>
        <artifactId>poi</artifactId>
        <version>3.14</version>
    </dependency>
    <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi-ooxml</artifactId>
        <version>3.14</version>
    </dependency>

程序代碼:

package com.zttech.demo.excel;


import java.io.BufferedInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Date;
import java.util.List;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
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.xssf.usermodel.XSSFWorkbook;
import org.junit.Test;

/**
 * Java讀取Excel內容
 * @author OrangQcer
 * @date 2018年3月20日
 */
public class ExcelOperate {

    @Test
    public void test() throws IOException {
        String filePath = "E:\\項目相關\\kms\\安全職責\\test01.xls";

        boolean isExcel2003 = true;  

        if (isExcel2007(filePath)) {  
            isExcel2003 = false;  
        }  

        File file = new File(filePath);

        String[][] result = getData(file, 1, isExcel2003);
        int rowLength = result.length;
        for (int i = 0; i < rowLength; i++) {
            for (int j = 0; j < result[i].length; j++) {
                System.out.print(result[i][j] + "|");
            }
            System.out.println("\t\t");
        }
    }

    /**
     * 讀取Excel的內容,第一維數組存儲的是一行中格列的值,二維數組存儲的是多少個行
     * @param file 讀取數據的源Excel
     * @param ignoreRows 讀取數據忽略的行數,比如行頭不需要讀入 忽略的行數爲1
     * @param isExcel2003 判斷Excel的格式,true爲xls,false爲xlsx
     * @return 讀出的Excel中數據的內容
     * @throws IOException 
     */
    private String[][] getData(File file, int ignoreRows, boolean isExcel2003) throws IOException {
        List<String[]> result = new ArrayList<>();
        int rowSize = 0;
        BufferedInputStream in = new BufferedInputStream(new FileInputStream(file));
        /** 打開Workbook */
        Workbook wb = null;
         if (isExcel2003) {  
             wb = new HSSFWorkbook(in);  
         }  
         else {  
             wb = new XSSFWorkbook(in);  
         }  
        Cell cell = null;
        /** 循環所有Sheet */
        for (int sheetIndex = 0; sheetIndex <wb.getNumberOfSheets(); sheetIndex++ ) {
            Sheet st = wb.getSheetAt(sheetIndex);
            /** 循環行,跳過標題  */
            for (int rowIndex = ignoreRows; rowIndex <= st.getLastRowNum(); rowIndex++ ) {
                Row row = st.getRow(rowIndex);
                if (row == null) {
                    continue;
                }
                int tempRowSize = row.getLastCellNum();
                if (tempRowSize > rowSize) {
                    rowSize = tempRowSize;
                }
                String[] values = new String[rowSize];
                Arrays.fill(values, "");
                boolean hasValue = false;
                for (int columnIndex = 0; columnIndex < row.getLastCellNum(); columnIndex ++) {
                    String value = "";
                    cell = row.getCell(columnIndex);
                    if (cell != null) {
                        switch (cell.getCellType()) {
                        case HSSFCell.CELL_TYPE_STRING:
                            value = cell.getStringCellValue();
                            break;
                        case HSSFCell.CELL_TYPE_NUMERIC:
                            if (HSSFDateUtil.isCellDateFormatted(cell)) {
                                Date date = cell.getDateCellValue();
                                if (date != null) {
                                    value = new SimpleDateFormat("yyyy-MM-dd").format(date);
                                } else {
                                    value = "";
                                }
                            } else {
                                value = new DecimalFormat("0").format(cell.getNumericCellValue());
                            }
                            break;
                        case HSSFCell.CELL_TYPE_FORMULA:
                            /** 入時如果爲公式生成的數據則無值  */
                            if (!cell.getStringCellValue().equals("")) {
                                value = cell.getStringCellValue();
                            } else {
                                value = cell.getNumericCellValue() + "";
                            }
                            break;
                        case HSSFCell.CELL_TYPE_BLANK:
                            value = "";
                            break;
                        case HSSFCell.CELL_TYPE_ERROR:
                            value = "";
                            break;
                        case HSSFCell.CELL_TYPE_BOOLEAN:
                            value = (cell.getBooleanCellValue() == true ? "Y" : "N");
                            break;
                        default:
                            value = "";
                        }
                    }
                    if (columnIndex == 0 && value.trim().equals("")) {
                        continue;
                    }
                    values[columnIndex] = value.trim();
                    hasValue  = true;
                }
                if (hasValue) {
                    result.add(values);
                }
            }
        }
        in.close();
        String[][] returnArray = new String[result.size()][rowSize];
        for (int i = 0; i <returnArray.length; i++) {
            returnArray[i] = result.get(i);
        }
        return returnArray;
    }

    public static boolean isExcel2003(String filePath) {  

        return filePath.matches("^.+\\.(?i)(xls)$");  

    }  
    public static boolean isExcel2007(String filePath) {  

        return filePath.matches("^.+\\.(?i)(xlsx)$");  

    }  

}

這個是要讀取的文件
test01.xls
下面是輸出的值,可以看到標題被跳過了,4行也被省略。
A2|B2|C2|
|B3|C3|
A5||C5|

之前看了網上的代碼有兩點小問題:
第一,如果一行的第一格爲空,那麼一整行都不會被讀取;
第二,每行的讀取都會多出一格。

另外,它會先判斷要讀取的文件是xls還是xlsx,避免版本不同報錯。

參考:
java解析獲取Excel中的數據--同時兼容2003及2007
Java讀取Excel內容

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