将从 mongo 返回的日期转换为此格式 2015-10-25



我有一个从 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);

相关内容

最新更新