Как преобразовать дату Java в OADate или наоборот?

Я хочу преобразовать Java Date в Microsoft OLE Automation — тип OADate или хочу преобразовать OADate в Java Date. Какова формула OADate для Java? На самом деле я искал в stackoverflow и не смог найти ответ, я получил ответ и хочу поделиться им с этим сообществом.

Например: 43013.7659837963 равно Чт 05 октября 18:23:01 EET 2017


person msari    schedule 20.04.2017    source источник


Ответы (1)


Преобразователь даты OLE Automation от Microsoft для 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);
    }

Как преобразовать 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();
}
person msari    schedule 20.04.2017