에서
감사합니다, OLE의 날짜는 1899-12-30 이후 날짜 수로 저장됩니다. 그 번호를 쉽게 계산할 수 있습니다. 당신이 그것을 가지고, 내가 생각하는 표준 변종을 사용하여 오른쪽 OLE 속성에 패스 - 그것.
불행하게도 나는 SWT 여기를 설치하지 않은 및 코드를 테스트 할 수 있지만, 그것은 완전한 예에 대한 found here을 할 수있는 Outlook의 자동화에 그
public class Test {
static Calendar OLE_BASE_DATE = Calendar.getInstance();
static {
OLE_BASE_DATE.set(1899, 11, 30); // 1899-12-30
}
static double oleDateFormat(Calendar cal) {
long diff = cal.getTimeInMillis() - OLE_BASE_DATE.getTimeInMillis();
return diff/86400000L;
}
public static void main(String[] args) {
// get outlook instance etc...
OleAutomation appointment = invoke(outlook, "CreateItem", 1).getAutomation();
appointment.setProperty(property(appointment, "Subject"), new Variant("Test"));
// compute the appointment start & stop
double todayAtNoon = oleDateFormat(Calendar.getInstance()) + 0.5;
double todayAt13_12 = oleDateFormat(Calendar.getInstance()) + 0.55;
// set the vars
appointment.setProperty(property(appointment, "Start"), new Variant(String.valueOf(todayAtNoon)));
appointment.setProperty(property(appointment, "End"), new Variant(String.valueOf(todayAt13_12)));
appointment.setProperty(property(appointment, "Location"), new Variant("At foo's"));
// do more stuff
}
}
더 많은 정보처럼 보일 것이다 VB
이 정보는 도움이 될 수 있습니다. http://stackoverflow.com/questions/2599102/oledate-java-implementation. 날짜는 1899 년 12 월 30 일 이후 일수를 나타내는 float 형식으로 저장됩니다. – Alex
자바에서 OLE 자동화 날짜를 얻는 방법은 무엇입니까? – Anu