Я ничего не мог найти. Я получаю 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;
}
}
Тьфу!