Java.temps.format.DateTimeParseException: Le texte n'a pas pu être analysé à l'index 21
J'obtiens la valeur datetime comme
created_at '2012-02-22T02:06:58.147Z'
Read-only. The time at which this task was created.
, Qui est donné par les Asanas API
J'utilise Java 8
pour analyser l'heure de la date comme suit
import java.time.*;
import java.time.format.*;
public class Times {
public static void main(String[] args) {
final String dateTime = "2012-02-22T02:06:58.147Z";
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'hh:mm:ss.SX");
final ZonedDateTime parsed = ZonedDateTime.parse(dateTime, formatter);
System.out.println(parsed);
}
}
Lorsque je lance ceci, j'obtiens l'erreur suivante
Exception in thread "main" java.time.format.DateTimeParseException: Text '2012-02-22T02:06:58.147Z' could not be parsed at index 21
at java.time.format.DateTimeFormatter.parseResolved0(DateTimeFormatter.java:1947)
at java.time.format.DateTimeFormatter.parse(DateTimeFormatter.java:1849)
at java.time.ZonedDateTime.parse(ZonedDateTime.java:597)
at Times.main(Times.java:11)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:497)
at com.intellij.rt.execution.application.AppMain.main(AppMain.java:140)
Qu'est-ce qui n'est pas juste ici?
4 answers
L'analyseur par défaut peut analyser votre entrée. Vous n'avez donc pas besoin d'un formateur personnalisé et
String dateTime = "2012-02-22T02:06:58.147Z";
ZonedDateTime d = ZonedDateTime.parse(dateTime);
Fonctionne comme prévu.
Si votre entrée, il a un fuseau horaire de "zulu" ("Z" = UTC), alors vous pouvez utiliser DateTimeFormatter.ISO_INSTANT
(implicitement):
final Instant parsed = Instant.parse(dateTime);
Si fuseau horaire varie et a la forme de "+01:00" ou "+01:00:00" (lorsqu'il n'est pas un "Z"), alors vous pouvez utiliser DateTimeFormatter.ISO_OFFSET_DATE_TIME
:
DateTimeFormatter formatter = DateTimeFormatter.ISO_OFFSET_DATE_TIME;
final ZonedDateTime parsed = ZonedDateTime.parse(dateTime, formatter);
, Si ce n'est pas le cas, vous pouvez construire une DateTimeFormatter
de la même manière que DateTimeFormatter.ISO_OFFSET_DATE_TIME
est construit.
Votre modèle actuel a plusieurs problèmes:
- ne pas utiliser le mode strict (
ResolverStyle.STRICT
); - en utilisant
yyyy
au lieu deuuuu
(yyyy
ne fonctionnera pas en mode strict); - à l'aide de 12 heures
hh
au lieu de 24 heuresHH
; - en utilisant un seul chiffre
S
pour les fractions de secondes, mais l'entrée en a trois.
Votre problème d'origine était un mauvais symbole de motif "h" qui représente l'heure de l'horloge (plage 1-12). Dans ce cas, les informations am-pm sont manquantes. Mieux, utilisez le symbole de motif "H" à la place (heure du jour dans la plage 0-23). Donc, le modèle aurait plutôt dû être comme:
Uuuu-MM-jj'T'HH: mm: ss.SSSX (meilleur modèle également adapté pour le mode strict)
Ce qui suit a fonctionné pour moi
import java.time.*;
import java.time.format.*;
public class Times {
public static void main(String[] args) {
final String dateTime = "2012-02-22T02:06:58.147Z";
DateTimeFormatter formatter = DateTimeFormatter.ISO_INSTANT;
final ZonedDateTime parsed = ZonedDateTime.parse(dateTime, formatter.withZone(ZoneId.of("UTC")));
System.out.println(parsed.toLocalDateTime());
}
}
Et m'a donné la sortie comme
2012-02-22T02:06:58.147