如何将Java Date转换为OADate或反之亦然?

我想将Java Date转换为Microsoft OLE Automation-OADate类型或想将OADa​​te转换为Java Date。OADate

for Java的公式是什么?实际上,我已经在stackoverflow中进行了搜索,但是找不到答案,我得到了答案,并且想在这个社区中分享它。

例如: 等于

回答:

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);

}

如何将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();

}

以上是 如何将Java Date转换为OADate或反之亦然? 的全部内容, 来源链接: utcz.com/qa/426461.html

回到顶部