我有一个从 mongo db 返回的 json 文件,如下所示:
[
{
"_id": {
"$date": "2014-10-19T04:00:00.000Z"
},
"value": 29
},
{
"_id": {
"$date": "2014-10-20T04:00:00.000Z"
},
"value": 20
},
{
"_id": {
"$date": "2014-10-21T04:00:00.000Z"
},
"value": 21
}
]
现在我想以以下格式读取 java 中的日期:2014/10/25
但是当我使用时:
System.out.println("DAte is : "+result.get("_id").toString() );
结果是 :
DAte is : Sun Oct 19 01:00:00 ADT 2014
然后我唯一想到的是使用子字符串并手动将日期转换为 2014-10-25,但我相信会有更好的方法。有人知道吗?
更新:
答案如下:
将日期从一种格式转换为另一种格式不起作用
非常感谢您的帮助
您可以使用此方法解析 mongo 日期格式。但在这里,我们忽略了时区。因此,如果时区无关紧要,请使用此选项。
private static String convertMongoDate(String val){
SimpleDateFormat inputFormat = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSS'Z'");
SimpleDateFormat outputFormat= new SimpleDateFormat("yyyy/MM/dd");
try {
String finalStr = outputFormat.format(inputFormat.parse(val));
System.out.println(finalStr);
return finalStr;
} catch (ParseException e) {
e.printStackTrace();
}
return "";
}
你为什么不使用DateTimeFormatter
?然后,您可以通过以下方式解析日期:
// The test string
String str = "Sun Oct 19 01:00:00 ADT 2014";
// Formatter for the input date
final DateTimeFormatter inputFormat =
DateTimeFormatter.ofPattern("EEE MMM dd HH:mm:ss zzz yyyy");
// The parsed date
final ZonedDateTime parsed = ZonedDateTime.parse(str, inputFormat);
// The output format(s). Specify the one you need
final DateTimeFormatter outputFormat1 = DateTimeFormatter.ofPattern("yyyy/MM/dd");
final DateTimeFormatter outputFormat2 = DateTimeFormatter.ofPattern("yyyy-MM-dd");
// Print
System.out.println(outputFormat1.format(parsed)); // -> 2014/10/19
System.out.println(outputFormat2.format(parsed)); // -> 2014-10-19
本文提供了一些有关如何解析和格式化日期的好读物。类DateTimeFormatter
可用于Java 8,如果您使用的是旧版本的Java,则可以改用类SimpleDateFormat
(它使用类似的策略来处理日期,但不幸的是不是线程安全的)。
编辑:从OP输入后更新了格式化程序
我建议你做下面这样的事情。
SimpleDateFormat original = new SimpleDateFormat("yyyy-MM-ddThh:mm:sssZ");
SimpleDateFormat output= new SimpleDateFormat("yyyy/MM/dd");
String isoFormat = original.format(result.get("_id"));
Date d = original.parse(isoFormat);
String formattedTime = output.format(d);
System.out.println(formattedTime);