poi讀取Excel文件並進行數據類型轉換實例


需要jar包:

poi-3.7.jar、poi-examples-3.7.jar、poi-ooxml-3.7.jar、poi-ooxml-schemas-3.7.jar、poi-scratchpad-3.7.jar

action代碼:

public String poiImportBusinessExcel(){   

    List<CaAvApply> caAvApplies = new ArrayList<CaAvApply>();

    InputStream input  = FileUtils.openInputStream(importFileExcel);

    POIFSFileSystem fs = new POIFSFileSystem(input);

    HSSFWorkbook wb = new HSSFWorkbook(fs);  

    HSSFSheet sheet = wb.getSheetAt(0);  

    Iterator rows = sheet.rowIterator();

    while(rows.hasNext()){

        HSSFRow row = (HSSFRow) rows.next();

        for(int i=0; i<caAvApplies.size(); i++){

            HSSFCell cell_1 = row.getCell(1);

            if(null != cell_1){

                aAvApplies.get(i).setName(changeCellToString(cell_1));

      (......其他行照此......)

}

        }

    }

}

(try catch略去了)

 

這里HSSFCell 有幾種數據類型,如果想進行類型轉換,再加一個方法進行轉換,這里給的例子是都轉換成String類型的數據

public String changeCellToString(HSSFCell cell){

String returnValue = "";

if(null != cell){

switch(cell.getCellType()){

case HSSFCell.CELL_TYPE_NUMERIC:   //數字

Double doubleValue = cell.getNumericCellValue();

String str = doubleValue.toString();

if(str.contains(".0")){

str = str.replace(".0", "");

}

Integer intValue = Integer.parseInt(str);

returnValue = intValue.toString();

break;

case HSSFCell.CELL_TYPE_STRING:    //字符串

returnValue = cell.getStringCellValue();

break;

case HSSFCell.CELL_TYPE_BOOLEAN:   //布爾

Boolean booleanValue=cell.getBooleanCellValue();

returnValue = booleanValue.toString();

break;

case HSSFCell.CELL_TYPE_BLANK:     // 空值

returnValue = "";

break;

case HSSFCell.CELL_TYPE_FORMULA:   // 公式

returnValue = cell.getCellFormula();

break;

case HSSFCell.CELL_TYPE_ERROR:     // 故障

returnValue = "";

break;

default:

System.out.println("未知類型");

break;

}

}

return returnValue;

}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM