此代码片段始终将日期解析为当前时区,而不是解析为正在解析的字符串中的时区。
final DateTimeFormatter df = DateTimeFormat
.forPattern("EEE MMM dd HH:mm:ss 'GMT'Z yyyy");
final DateTime dateTime = df
.parseDateTime("Mon Aug 24 12:36:46 GMT+1000 2009");
System.out.println("dateTime = " + dateTime);
// outputs dateTime = 2009-08-24T04:36:46.000+02:00
输出:
dateTime = 2009-08-24T04:36:46.000+02:00
而我期待:
dateTime = 2009-08-24T04:36:46.000+10:00
任何想法我做错了什么?
答案 0 :(得分:75)
好的,进一步的谷歌搜索给了我自己问题的答案:使用withOffsetParsed()
,如下:
final DateTimeFormatter df = DateTimeFormat
.forPattern("EEE MMM dd HH:mm:ss 'GMT'Z yyyy");
final DateTime dateTime = df.withOffsetParsed()
.parseDateTime("Mon Aug 24 12:36:46 GMT+1000 2009");
这很有效。
答案 1 :(得分:35)
你也可以选择:
// parse using the Paris zone
DateTime date = formatter.withZone(DateTimeZone.forID("Europe/Paris")).parseDateTime(str);
答案 2 :(得分:1)
下面引用的是来自 home page of Joda-Time 的通知:
<块引用>请注意,从 Java SE 8 开始,要求用户迁移到 java.time (JSR-310) - JDK 的核心部分,取代了该项目。
不要像您所做的那样为时区使用固定文本(例如 'GMT'
),因为该方法可能无法用于其他语言环境。
使用 java.time
(现代日期时间 API)的解决方案:
import java.time.OffsetDateTime;
import java.time.format.DateTimeFormatter;
import java.util.Locale;
public class Main {
public static void main(String[] args) {
String strDateTime = "Mon Aug 24 12:36:46 GMT+1000 2009";
DateTimeFormatter parser = DateTimeFormatter.ofPattern("E MMM d H:m:s VVZ u", Locale.ENGLISH);
OffsetDateTime odt = OffsetDateTime.parse(strDateTime, parser);
System.out.println(odt);
// Custom fromat
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("uuuu-MM-dd'T'HH:mm:ss.SSSXXX", Locale.ENGLISH);
System.out.println(formatter.format(odt));
}
}
输出:
2009-08-24T12:36:46+10:00
2009-08-24T12:36:46.000+10:00
从 Trail: Date Time 了解有关现代 Date-Time API 的更多信息。
* 出于任何原因,如果您必须坚持使用 Java 6 或 Java 7,您可以使用 ThreeTen-Backport,它将大部分 java.time 功能向后移植到 Java 6 & 7. 如果您正在为 Android 项目工作并且您的 Android API 级别仍然不符合 Java-8,请检查 Java 8+ APIs available through desugaring 和 How to use ThreeTenABP in Android Project。