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
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.
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.
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.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.
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
.