Convert date into AEST using java

前端 未结 2 1418
时光取名叫无心
时光取名叫无心 2020-12-04 04:21

I want to convert below date into AEST format using Java.

2018-01-08T02:10:24.000+0000w

Below is the code which i am using for

相关标签:
2条回答
  • 2020-12-04 04:47

    You have to use the formatter when parsing the date string. Also you need to tell it to change the zone or zone offset to get it into AEST/AEDT.

    This might work:

    DateTimeFormatter dtf = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ss.SSSXX"); 
    ZonedDateTime zdt = OffsetDateTime.parse(input, dtf)
        .atZoneSameInstant(ZoneId.of("Australia/Sydney"));
    String dateInTimeZone = zdt.format(dtf);
    

    The offset will appear as "+1000" or "+1100" depending on the time of year.

    0 讨论(0)
  • 2020-12-04 04:59

    The accepted answer by @HankD is a good one. Since I find myself sometimes linking to this question (typically from duplicates), I should like to provide an alternative and a little further information.

    My assumptions

    • AEST is not a format. It’s a time zone abbreviation, and while four letter time zone abbreviations are often ambiguous, I believe we can take AEST to be Australian Eastern Standard Time, the time used in the Australia/Sydney time zone during standard time (what you want during summer time (DST) is not perfectly clear).
    • I am assuming that the trailing w of your date and time string is a typo. Without it your format becomes ISO 8601, which makes all the sense in the world. I have never seen such a w in a date time string elsewhere.

    Two ways to construct a formatter

    For the sake of completeness I should like to present two ways you may built a formatter that can parse your string, each with their pros and cons.

    1. Reusing built-in functionality

        String lastModifiedString = "2018-01-08T02:10:24.000+0000";
    
        DateTimeFormatter formatter = new DateTimeFormatterBuilder()
                .append(DateTimeFormatter.ISO_LOCAL_DATE)
                .appendLiteral('T')
                .append(DateTimeFormatter.ISO_LOCAL_TIME)
                .appendOffset("+HHmm", "Z")
                .toFormatter();
    
        OffsetDateTime odt = OffsetDateTime.parse(lastModifiedString, formatter);
    
        ZonedDateTime zdt = odt.atZoneSameInstant(ZoneId.of("Australia/Sydney"));
        System.out.println(zdt);
    

    Output:

    2018-01-08T13:10:24+11:00[Australia/Sydney]

    Pro: Probably the clearer to read and less error-prone. More flexible: accepts presence and absence of seconds and up to 9 decimals of fractional seconds (or you may consider this a disadvantage if you want the strictest possible validation of your string). Con: wordier.

    2. Writing a format pattern string

    The other way to construct the formatter is the one also use in the other answer:

        DateTimeFormatter formatter
                = DateTimeFormatter.ofPattern("uuuu-MM-dd'T'HH:mm:ss.SSSXX");
    

    The rest of the code is the same, and so is the output. Pro: brief. Con: More error-prone and less straight-forward to read. Inflexible: requires exactly three decimals on the seconds.

    As an aside, while the classes of java.time generally parse the most common ISO 8601 format variants without any explicit formatter, the variant where there is no colon in the offset ( +0000 rather than +00:00) is the most prominent exception. So given that we don’t want to hand manipulate the input string, constructing a custom formatter in one of the two ways shown is our best bet.

    There is something wrong with the pattern?

    Yes, using zzz doesn’t work for parsing an offset. According to the documentation (link at the bottom) , lowercase z is for time zone name such as Australian Eastern Standard Time or AEST. For an offset like +0000 you need either uppercase X, lowercase x or uppercase Z.

    Links

    • Wikipedia article: ISO 8601
    • Documentation of DateTimeFormatter including the various format pattern letters.
    0 讨论(0)
提交回复
热议问题