我想要将 Java Date 转换为 Microsoft OLE Automation - OADate 类型,或者想要将 OADate 转换为 Java Date。 Java 的 OADate 的公式是什么?
其实我在stackoverflow上搜索过并没有找到答案,我得到了答案并想在这个社区分享。
例如:43013.7659837963等于2017 年东部时间 10 月 5 日星期四 18:23:01
Microsoft 的 Java OLE 自动化日期转换器
如何将 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);
}
如何将 OADate 转换为 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();
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)