На этот вопрос уже есть ответ здесь:
Я нигде не нашел этого. Я получить JSON из API, который возвращает стандартные даты JSON. Вы можете увидеть формат, запустив этот код в консоли JavaScript:
> new Date().toJSON();
"2010-10-27T11:58:22.973Z"
Ну, на самом деле API, с которым я работаю, не возвращает миллисекундную часть, а иногда и возвращает часовой пояс вместо Z
, поэтому даты могут выглядеть как одно из следующих:
2010-10-27T11: 58: 22Z
2010-10-27T11: 58: 22 + 03: 00
Синтаксический анализ таких дат несколько обременительный. Есть ли способ анализировать такие даты с помощью org.json
?
Мое текущее решение:
public static Date parseDateTime(String dateString) {
if (dateString == null) return null;
DateFormat fmt = new SimpleDateFormat("yyyy-MM-dd HH:mm:ssZ");
if (dateString.contains("T")) dateString = dateString.replace('T', ' ');
if (dateString.contains("Z")) dateString = dateString.replace("Z", "+0000");
else
dateString = dateString.substring(0, dateString.lastIndexOf(':')) + dateString.substring(dateString.lastIndexOf(':')+1);
try {
return fmt.parse(dateString);
}
catch (ParseException e) {
Log.e(Const.TAG, "Could not parse datetime: " + dateString);
return null;
}
}
Ух!