字符串是一个输入,我必须检查它是否是这些格式中的任何一种。如果它是 sdf1 格式然后通过,如果它是 sdf2,3 .... 然后我添加缺少的格式并用 sdf1 格式解析它
SimpleDateFormat sdf1 = new SimpleDateFormat("MM/dd/yyyy hh:mm:ss a");
SimpleDateFormat sdf2 = new SimpleDateFormat("MM/dd/yyyy hh:mm:ssa");
SimpleDateFormat sdf3 = new SimpleDateFormat("MM/dd/yyyy hh:mm a");
SimpleDateFormat sdf3 = new SimpleDateFormat("MM/dd/yyyy hh:mma");
SimpleDateFormat sdf3 = new SimpleDateFormat("MM/dd/yyyy hh:mm");
SimpleDateFormat sdf3 = new SimpleDateFormat("MM/dd/yyyy");
这是我所拥有的
try{
// Parse if it is MM/dd/yyyy hh:mm:ss a
cal = Calendar.getInstance();
cal.setTime(sdf1.parse(inStr));
}catch(Exception exp){
try{
cal = Calendar.getInstance();
//Parse if it is MM/dd/yyyy hh:mm:ssa
sdf2.parse(inStr);
inStr = new StringBuilder(inStr).insert(str.length()-2, " ").toString();
cal.setTime(sdf1.parse(inStr));
}catch(Exception dte2){
try{
cal = Calendar.getInstance();
//Parse if it is MM/dd/yyyy hh:mma
sdf3.parse(inStr);
//if pass then set 00:00:00 AM
inStr = inStr+" AM";
inStr = new StringBuilder(inStr).insert(str.length()-2, ":00").toString();
cal.setTime(sdf1.parse(inStr));
它继续像尝试解析一样进行,如果在异常块检查中失败,则为下一个解析。有没有什么简单的方法可以做到这一点,可能在 JAVA 8 中?我可以使用标记为重复的链接,它讨论如何解析,但我有额外的要求作为自动完成缺少格式。
在 Java 8 中,您可以使用java.time.format.DateTimeFormatter
带有许多可选部分的 a - 由 分隔[]
:
DateTimeFormatter fmt = DateTimeFormatter
.ofPattern("MM/dd/yyyy[ hh:mm[[:ss][ ]a]][HH:mm]", Locale.US);
如果您只想验证输入 - 并且不将结果分配给日期/时间变量 - 只需调用parse
就足够了。这适用于以下所有情况:
fmt.parse("10/20/2018");
fmt.parse("10/20/2018 10:20");
fmt.parse("10/20/2018 10:20AM");
fmt.parse("10/20/2018 10:20 AM");
fmt.parse("10/20/2018 10:20:30AM");
fmt.parse("10/20/2018 10:20:30 AM");
如果输入无效,它会抛出一个DateTimeParseException
.
请注意,和之间存在差异HH
hh
。H
用于一天中的小时(值介于 0 和 23 之间),而h
用于时钟小时的上午 - 下午(值介于 1 和 12 之间)。H
不能带有 AM/PM 指示符,而h
必须有 AM/PM 来消除歧义。这就是为什么有 2 个不同的可选部分,每个字段一个。
我也使用,Locale.US
因为 AM/PM 字符串是本地化的。尽管对于大多数语言环境,结果是“AM”或“PM”,但对于其他一些语言环境,它可以是小写字母(“am”)或其他一些值(午後
例如日语)。
如果您不设置语言环境,它将使用 JVM 默认值。但我更喜欢将它设置为一个特定的,我知道它可以与我拥有的输入一起使用。
要再次打印这些值,以及所有字段,这有点棘手。输入只能有日期(日、月、年)或日期和时间(日、月、年、小时、分钟),因此一种替代方法是使用 a LocalDateTime
(并在不存在时设置缺失的字段)。
您可以使用parseBest
然后检查被解析的类型:
// parse, try to create a LocalDateTime - if it's not possible, try a LocalDate
TemporalAccessor parsed = fmt.parseBest("10/20/2018", LocalDateTime::from, LocalDate::from);
LocalDateTime dt = null;
if (parsed instanceof LocalDateTime) {
// LocalDateTime parsed (all fields set)
dt = (LocalDateTime) parsed;
} else if (parsed instanceof LocalDate) {
// LocalDate parsed (set time fields)
dt = ((LocalDate) parsed)
// set time (use whatever value you want - I'm using 10 AM as example)
.atTime(LocalTime.of(10, 0));
}
然后您使用另一个格式化程序进行输出 - 这是因为第一个格式化程序将在格式化时打印所有可选部分,因此它将打印两次小时。只需创建另一个,就是这样:
DateTimeFormatter outputFmt = DateTimeFormatter.ofPattern("MM/dd/yyyy hh:mm:ss a", Locale.US);
System.out.println(dt.format(outputFmt)); // 10/20/2018 10:00:00 AM
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句