我正在尝试将表示 AM/PM 格式的时间的字符串转换为 java.sql.Time,但我得到一个 DateTimeParseException:
public static java.sql.Time getTimeValue(String valStr) {
if (valStr == null || valStr.isEmpty()) {
return null;
}
DateTimeFormatter dateTimeFormatter;
if (valStr.toUpperCase().endsWith("AM") || valStr.toUpperCase().endsWith("PM")) {
dateTimeFormatter = DateTimeFormatter.ofPattern("h:mm a");
} else {
dateTimeFormatter = DateTimeFormatter.ofPattern("HH:mm");
}
try {
return java.sql.Time.valueOf(LocalTime.parse(valStr, dateTimeFormatter));
} catch (Exception ex) {
return null;
}
}
对于“7:16 PM”的输入值,我得到以下异常:
java.time.format.DateTimeParseException: Text '7:16 PM' could not be parsed at index 5
at java.base/java.time.format.DateTimeFormatter.parseResolved0(DateTimeFormatter.java:2046)
at java.base/java.time.format.DateTimeFormatter.parse(DateTimeFormatter.java:1948)
at java.base/java.time.LocalTime.parse(LocalTime.java:463)
at ...getTimeValue(....java:864)
我正在使用 Java 11.0.5,Zulu 11.35.15 用于 64 位。
有谁知道为什么这不起作用?我对 Java 8 中的同一段代码没有任何问题。
我检查了 DateTimeFormatter 的值,它是对应于“h:mm a”模式的值。