Android解析和格式化DateTime时间戳

时间:2015-08-11 17:50:49

标签: java android datetime

我需要Android / Java文本格式的帮助。我一直在努力解决如何从SQLite数据库中解析和格式化Google DateTime字符串的问题。我得到的错误是

E/TAG﹕ Parsing ISO8601 datetime failed
    java.text.ParseException: Unparseable date: "2015-08-04T18:20:00.000-04:00" (at offset 10)
            at java.text.DateFormat.parse(DateFormat.java:579)

我写的方法是

import java.util.Date;
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.TimeZone;

...

public String formatDueDate(String queryResponse) {
        DateFormat iso8601Format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        Date date = new Date();
        try {
             date = iso8601Format.parse(queryResponse);
        } catch (ParseException e) {
            Log.e("TAG", "Parsing ISO8601 datetime failed", e);
        }

        long when = date.getTime();
        int flags = 0;
        flags |= android.text.format.DateUtils.FORMAT_SHOW_TIME;
        flags |= android.text.format.DateUtils.FORMAT_SHOW_DATE;
        flags |= android.text.format.DateUtils.FORMAT_ABBREV_MONTH;
        flags |= android.text.format.DateUtils.FORMAT_SHOW_YEAR;

       return android.text.format.DateUtils.formatDateTime(mContext,
                when + TimeZone.getDefault().getOffset(when), flags);

    }

1 个答案:

答案 0 :(得分:2)

尝试从

进行更改
DateFormat iso8601Format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

DateFormat iso8601Format = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSZ");