ecxcle 對於日期的處理

Excel數據處理:

Excel存儲日期、時間均以數值類型進行存儲,讀取時POI先判斷是是否是數值類型,再進行判斷轉化

1、數值格式(CELL_TYPE_NUMERIC):

1.純數值格式:getNumericCellValue() 直接獲取數據

2.日期格式處理yyyy-MM-dd, d/m/yyyy h:mm, HH:mm 等不含文字的日期格式

1).判斷是否是日期格式:HSSFDateUtil.isCellDateFormatted(cell)

2).判斷是日期或者時間

cell.getCellStyle().getDataFormat() == HSSFDataFormat.getBuiltinFormat("h:mm")

OR: cell.getCellStyle().getDataFormat() == HSSFDataFormat.getBuiltinFormat("yyyy-MM-dd")

3.自定義日期格式處理yyyy年m月d日,h時mm分,yyyy年m月等含文字的日期格式

判斷cell.getCellStyle().getDataFormat()值,解析數值格式

yyyy年m月d日----->31

m月d日---->58

h時mm分--->32

2、字符格式(CELL_TYPE_STRING):直接獲取內容

//對取得的列中的數據類型進行判斷
	public  String  getCellValue(HSSFCell cell) {  
        String cellValue = "";  
        DecimalFormat df = new DecimalFormat("#");  
      	  switch (cell.getCellType()) {  
            case HSSFCell.CELL_TYPE_STRING:  
                cellValue = cell.getRichStringCellValue().getString().trim();  
                break;  
            case HSSFCell.CELL_TYPE_NUMERIC: 
            	if(HSSFDateUtil.isCellDateFormatted(cell)) {  //處理日期格式、時間格式
            		SimpleDateFormat sdf=null;
            		 if (cell.getCellStyle().getDataFormat() == HSSFDataFormat.getBuiltinFormat("h:mm")) {  
                         sdf = new SimpleDateFormat("HH:mm");  
                     } else {// 日期  
                         sdf = new SimpleDateFormat("yyyy-MM-dd");  
                     }  
                     Date date = cell.getDateCellValue(); 
                     cellValue=sdf.format(date);
            	}else if(cell.getCellStyle().getDataFormat()==58) {  //處理 自定義日期格式,m月m日(通過判斷單元格的格式解決,id值是58 )
            		 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");  
                     double value = cell.getNumericCellValue();  
                     Date date = org.apache.poi.ss.usermodel.DateUtil  
                             .getJavaDate(value);  
                     cellValue=sdf.format(date);
            	}else {
            		cellValue = df.format(cell.getNumericCellValue()).toString();  
            	}
                break;  
            case HSSFCell.CELL_TYPE_BOOLEAN:  
                cellValue = String.valueOf(cell.getBooleanCellValue()).trim();  
                break;  
            case HSSFCell.CELL_TYPE_FORMULA:  
                cellValue = cell.getCellFormula();  
                break;  
            default:  
            	 cellValue = "";
            }  
        return cellValue.toString();  
    } 

3.

 *萬能處理方案

所有日期格式都可以通過getDataFormat()值來判斷

yyyy-MM-dd----- 14

yyyy年m月d日--- 31

yyyy年m月------- 57

m月d日  ---------- 58

HH:mm----------- 20

h時mm分  ------- 32


//1、判斷是否是數值格式  
if(cell.getCellType() == HSSFCell.CELL_TYPE_NUMERIC){  
    short format = cell.getCellStyle().getDataFormat();  
    SimpleDateFormat sdf = null;  
    if(format == 14 || format == 31 || format == 57 || format == 58){  
        //日期  
        sdf = new SimpleDateFormat("yyyy-MM-dd");  
    }else if (format == 20 || format == 32) {  
        //時間  
        sdf = new SimpleDateFormat("HH:mm");  
    }  
    double value = cell.getNumericCellValue();  
    Date date = org.apache.poi.ss.usermodel.DateUtil.getJavaDate(value);  
    result = sdf.format(date);  
}  



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