![](/img/trans.png)
[英]LocalDateTime - deserialization with LocalDateTime.parse
[英]missing second(00) from LocalDateTime.parse
缺少LocalDateTime.parse
第二個 (00)
LocalTime time = LocalTime.NOON;
DateTimeFormatter formatTime = DateTimeFormatter.ofPattern("HH:mm:ss");
String value ="20200810" + time.format(formatTime);
LocalDateTime localDateTime = LocalDateTime.parse(value, DateTimeFormatter.ofPattern("yyyyMMddHH:mm:ss"));
日志
=========value========== 2020081012:00:00
===localDateTime===2020-08-10T**12:00**
我試圖改變LocalTime.NOON
到LocalTime.of(12,0,0)
太多,但還是同樣的結果。
將以下行寫入日志:
localDateTime.format(DateTimeFormatter.ISO_LOCAL_DATE_TIME)
上面的行根據DateTimeFormatter.ISO_LOCAL_DATE_TIME
返回一個字符串。
您還可以根據您的要求指定自定義模式,例如
localDateTime.format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"))
或者
localDateTime.format(DateTimeFormatter.ofPattern("yyyyMMddHH:mm:ss"))
如果直接打印localDateTime
,它會打印LocalDateTime
的toString
方法返回的字符串。
請注意,由於時間中的second
部分12:00:00
是00
,因此LocalDateTime
的默認toString
實現會忽略second
部分。
供您參考,下面給出的是LocalDateTime
的toString()
實現:
@Override
public String toString() {
return date.toString() + 'T' + time.toString();
}
並在下面給出LocalTime
的toString()
實現:
@Override
public String toString() {
StringBuilder buf = new StringBuilder(18);
int hourValue = hour;
int minuteValue = minute;
int secondValue = second;
int nanoValue = nano;
buf.append(hourValue < 10 ? "0" : "").append(hourValue)
.append(minuteValue < 10 ? ":0" : ":").append(minuteValue);
if (secondValue > 0 || nanoValue > 0) {
buf.append(secondValue < 10 ? ":0" : ":").append(secondValue);
if (nanoValue > 0) {
buf.append('.');
if (nanoValue % 1000_000 == 0) {
buf.append(Integer.toString((nanoValue / 1000_000) + 1000).substring(1));
} else if (nanoValue % 1000 == 0) {
buf.append(Integer.toString((nanoValue / 1000) + 1000_000).substring(1));
} else {
buf.append(Integer.toString((nanoValue) + 1000_000_000).substring(1));
}
}
}
return buf.toString();
}
如您所見,僅當second
部分和nano
部分的值大於0
時才包含它們。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.