3

我正在尝试将表示 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”模式的值。

4

1 回答 1

2

非常感谢 John Skeet 和 Robert,确实,这是一个语言环境问题。

  • 在我的最小示例中,一切都按预期工作,但那是因为我有美国语言环境。
  • 在生产代码中,语言环境来自德语,似乎根本不存在 AM/PM。日期格式来自将信息导出到我们的应用程序的外部设备。

解决方案是始终使用 Locale.US 参数创建 DateTimeFormatter,因此现在一切都按预期工作。

if (valStr.toUpperCase().endsWith("AM") || valStr.toUpperCase().endsWith("PM")) {
  dateTimeFormatter = DateTimeFormatter.ofPattern("h:mm a", Locale.US);
} else {
  dateTimeFormatter = DateTimeFormatter.ofPattern("HH:mm");
}
于 2019-12-18T18:27:47.553 回答