2017-04-20 358 views
0

我想將Java Date轉換爲Microsoft OLE Automation - OADate類型或想要將OADa​​te轉換爲Java Date。 OADate for Java的公式是什麼? 其實我已經在stackoverflow搜索,並找不到答案,我得到了答案,並希望在這個社區分享。如何將Java日期轉換爲OADate或反之亦然?

例如: 43013.7659837963等於週四10月5 18時23分01秒EET 2017年

回答

1

微軟的OLE自動化日期轉換爲Java

如何將Java日期轉換爲OADate:

/** 
    * Convert Date to Microsoft OLE Automation - OADate type 
    * @param date 
    * @return 
    * @throws ParseException 
    */ 
    public static String convertToOADate(Date date) throws ParseException { 
    double oaDate; 
    SimpleDateFormat myFormat = new SimpleDateFormat("dd MM yyyy"); 
    Date baseDate = myFormat.parse("30 12 1899"); 
    Long days = TimeUnit.DAYS.convert(date.getTime() - baseDate.getTime(), TimeUnit.MILLISECONDS); 

    oaDate = (double) days + ((double) date.getHours()/24) + ((double) date.getMinutes()/(60 * 24)) + ((double)      date.getSeconds()/(60 * 24 * 60)); 
    return String.valueOf(oaDate); 
    } 

如何將OADa​​te轉換爲Java日期:

/** 
* Convert Microsoft un OLE Automation - OADate to Java Date. 
* @param date 
* @return 
* @throws ParseException 
*/ 
public static Date convertFromOADate(double d) throws ParseException { 
    double mantissa = d - (long) d; 
    double hour = mantissa*24; 
    double min =(hour - (long)hour) * 60; 
    double sec=(min- (long)min) * 60; 


    SimpleDateFormat myFormat = new SimpleDateFormat("dd MM yyyy"); 
    Date baseDate = myFormat.parse("30 12 1899"); 
    Calendar c = Calendar.getInstance(); 
    c.setTime(baseDate); 
    c.add(Calendar.DATE,(int)d); 
    c.add(Calendar.HOUR,(int)hour); 
    c.add(Calendar.MINUTE,(int)min); 
    c.add(Calendar.SECOND,(int)sec); 

    return c.getTime(); 
} 
相關問題