我有一个函数,它接受日期并提供 XMLGregorianCalendar 格式的日期,如下所示,当日期提供为 2017- 时,该函数返回日期为
2017-11-30T00:00:00.000-08:00
11-30
public static String xmlDate(Date date) {
XMLGregorianCalendar xmlDate = null;
if (date != null) {
GregorianCalendar gc = new GregorianCalendar();
Calendar cal = Calendar.getInstance();
cal.setTime(date);
gc.setTimeZone(TimeZone.getTimeZone("America/Los_Angeles"));
gc.set(cal.get(Calendar.YEAR), cal.get(Calendar.MONTH), cal.get(Calendar.DAY_OF_MONTH), 0, 0, 0);
gc.set(Calendar.MILLISECOND, 0);
try {
xmlDate = DatatypeFactory.newInstance().newXMLGregorianCalendar(gc);
} catch (DatatypeConfigurationException e) {
//exception
}
}
return xmlDate.toString();
}
我正在尝试使用 Java 8 ZonedDateTime 重写上述函数,但获取的日期为 2017-11-29T00:00:00-08:00
。如何才能获得与以上功能?我也不明白为什么日期是 29 而不是 30。
public static String zonedDatetime(Date date) {
return ZonedDateTime.ofInstant(date.toInstant(), ZoneId.of("America/Los_Angeles"))
.truncatedTo(ChronoUnit.DAYS)
.format(DateTimeFormatter.ISO_OFFSET_DATE_TIME);
}
最佳答案
假设日期
是此时此刻,那么您得到 29 号的原因是因为这是此时洛杉矶的日期(太平洋标准时间 22:53)。
如果您想匹配本地日期,那么您可能会遇到这样的事情:
return ZonedDateTime.ofInstant(date.toInstant(), ZoneId.systemDefault())
.withZoneSameLocal(ZoneId.of("America/Los_Angeles"))
.truncatedTo(ChronoUnit.DAYS)
.format(DateTimeFormatter.ISO_OFFSET_DATE_TIME)
关于datetime - ZonedDateTime 中的 XMLGregorianCalendar 格式日期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47567449/