POI對Excel自定義日期格式的讀取
學習了:http://yl-fighting.iteye.com/blog/1726285
cell.getCellStyle().getDataFormat();根據這個值進行時間、日期格式的判斷;
POI讀取出來的結果也是有些變化的;需要在實際項目中進行確認;
日期格式的遍歷:Excel2007和Excel2003都是這樣的結果;

時間格式的遍歷:

增加了其它日期格式的處理:
// 讀取cell單元格的值,如果為日期格式,進行轉換 @SuppressWarnings("deprecation") public String getCellValue(Cell cell) { if (cell == null) return ""; if (cell.getCellType() == Cell.CELL_TYPE_STRING) { return cell.getStringCellValue(); } else if (cell.getCellType() == Cell.CELL_TYPE_BOOLEAN) { return String.valueOf(cell.getBooleanCellValue()); } else if (cell.getCellType() == Cell.CELL_TYPE_FORMULA) { return cell.getCellFormula(); } else if (cell.getCellType() == Cell.CELL_TYPE_NUMERIC) { short format = cell.getCellStyle().getDataFormat(); System.out.println("format:"+format+";;;;;value:"+cell.getNumericCellValue()); SimpleDateFormat sdf = null; if (format == 14 || format == 31 || format == 57 || format == 58 || (176<=format && format<=178) || (182<=format && format<=196) || (210<=format && format<=213) || (208==format ) ) { // 日期 sdf = new SimpleDateFormat("yyyy-MM-dd"); } else if (format == 20 || format == 32 || format==183 || (200<=format && format<=209) ) { // 時間 sdf = new SimpleDateFormat("HH:mm"); } else { // 不是日期格式 return String.valueOf(cell.getNumericCellValue()); } double value = cell.getNumericCellValue(); Date date = org.apache.poi.ss.usermodel.DateUtil.getJavaDate(value); if(date==null || "".equals(date)){ return ""; } String result=""; try { result = sdf.format(date); } catch (Exception e) { e.printStackTrace(); return ""; } return result; } return ""; }
