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?

Author: softarn, 2016-03-09

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.

 6
Author: assylias, 2016-03-09 07:45:29

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 de uuuu (yyyy ne fonctionnera pas en mode strict);
  • à l'aide de 12 heures hh au lieu de 24 heures HH;
  • en utilisant un seul chiffre S pour les fractions de secondes, mais l'entrée en a trois.
 11
Author: Roman, 2016-03-09 02:46:34

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)

 2
Author: Meno Hochschild, 2016-03-09 03:13:45

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
 0
Author: daydreamer, 2016-03-09 02:23:05