如何解决如何在Java中最好地确定日期格式是MM / dd还是DD / mm
我有文件列表,需要使用Java进行分析。从文件中读取日期字段为String
,我需要将其解析为LocalDatTime
。问题在于,现在知道日期的第一部分是月还是日。
其中的格式可以是任何格式,但很可能采用以下格式。
"yyyy-MM-dd HH:mm:ss","dd/MM/yyyy HH:mm","MM/dd/yyyy HH:mm","yyyy-MM-dd HH:mm","MM/dd/yy HH:mm"
例如
9/8/2020 23:50
9/8/2020 23:55
9/9/2020 00:00
在上述情况下,可以根据日期从9/8/2020 23:50
更改时开始猜测日期字段
9/9/2020 00:00
。这意味着日期从8号更改为9号,因此格式为MM/dd/yyyy HH:mm
9/8/2020 23:00
9/8/2020 23:50
10/8/2020 00:00
在上述情况下,可以根据日期从9/8/2020 23:55
更改时开始猜测日期字段
10/9/2020 00:00
。这意味着日期从9日更改为10日,因此格式为dd/MM/yyyy HH:mm
文件也可以是2020-09-08 23:00:00
。我唯一知道的是日期将在系列中更改,而月份很少更改。
解决方法
其中一种解决方法可能就是只计算第一部分和第二部分的变化并比较结果。这不是特别有效,但很简单:
// true - day/month/year
// false - month/day
public static boolean isDayMonthYearFormat(List<String> sortedDates) {
int firstPartChangeAmount = 0;
int secondPartChangeAmount = 0;
int prvOne = -1;
int prvTwo = -1;
boolean count = false;
for (String date : sortedDates) {
String[] parts = date.split("[\\/\\s+:]");
int one = Integer.parseInt(parts[0]);
int two = Integer.parseInt(parts[1]);
if (count) {
firstPartChangeAmount += prvOne < one ? 1 : 0;
secondPartChangeAmount += prvTwo < two ? 1 : 0;
}
count = true;
prvOne = one;
prvTwo = two;
}
if (firstPartChangeAmount == secondPartChangeAmount)
throw new RuntimeException("can't detect between MM/dd and DD/mm");
return firstPartChangeAmount > secondPartChangeAmount;
}
输出:
System.out.println(isDayMonthYearFormat(Arrays.asList("9/8/2020 23:50","9/8/2020 23:55","9/9/2020 00:00"))); // false
System.out.println(isDayMonthYearFormat(Arrays.asList("9/8/2020 23:00","9/8/2020 23:50","10/8/2020 00:00"))); // true
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。