我正在开发一个项目,该项目从IST
(印度标准时间)的后端获取日期/时间,如"2013-01-09T19:32:49.103+05:30"
所示。但是,当我使用以下DateFormat
DateFormat sdf = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSZ");
然后解析..
Date date = sdf.parse("2013-01-09T19:32:49.103+05:30");
System.out.println("XYZ ==============>"+date);
以GMT格式显示日期作为输出,即
Wed Jan 09 14:02:49 GMT+00:00 2013.
我尝试使用TimeZone类作为..
TimeZone timeZone=TimeZone.getTimeZone("IST");
sdf.setTimeZone(timeZone);
但没有效果..
我怎样才能获得Date
类对象的日期为IST
格式而不是GMT ...
请提供适当的解决方案..
修改
这就是代码的样子:
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSZ");
TimeZone timeZone=TimeZone.getTimeZone("IST");
sdf.setTimeZone(timeZone);
Date date = sdf.parse("2013-01-09T19:32:49.103+05:30");
String formattedDate=sdf.format(date);
System.out.println("XYZ ==============>"+formattedDate);
答案 0 :(得分:24)
日期没有任何时区。它只是自1970年1月1日00:00:00 GMT以来的毫秒数的持有者。使用您用于解析的相同DateFormat,设置IST时区并设置日期格式,如下例所示
DateFormat sdf = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSXXX");
Date date = sdf.parse("2013-01-09T19:32:49.103+05:30");
sdf.setTimeZone(TimeZone.getTimeZone("IST"));
System.out.println(sdf.format(date));
输出
2013-01-09T19:32:49.103+05:30
请注意,自{1.7}起,XX
X模式用于ISO 8601时区(-08:00)。如果您在1.6中尝试Z
。有关格式模式的详细信息,请参阅SimpleDateFormat API
答案 1 :(得分:3)
我怎么能得到一个Date类对象,其中包含IST格式的日期而不是GMT ...
你做不到。 Date
没有格式或时区。它简单地表示自1970年1月1日午夜的Unix时代以来的毫秒数。相反,Date.toString()
始终使用默认时区。
要使用特定格式和时区,请使用DateFormat
代替Date.toString()
。您可以使用DateFormat.setTimeZone()
设置时区,然后使用DateFormat.format()
将Date
转换为String
。 DateFormat
本身有一些工厂方法可供创建,或者如果要指定特定模式,则可以使用SimpleDateFormat
。
正如阿布所说,Joda Time 是比内置API更好的日期/时间API,尽管只是格式化日期/时间标准库不会做糟糕的工作。请注意,DateFormat
及其子类通常不是线程安全的。
答案 2 :(得分:2)
OffsetDateTime.parse( "2013-01-09T19:32:49.103+05:30" ) // Parsed.
.toInstant() // Adjusted to UTC.
您的2013-01-09T19:32:49.103+05:30
输入字符串恰好是标准的ISO 8601格式。最后+05:30
表示提前五个半小时offset-from-UTC,在印度使用。
你正在使用麻烦的旧日期时间类,现在是旧的,取而代之的是java.time类。
在解析/生成表示日期时间值的字符串时,java.time类默认使用ISO 8601格式。所以根本不需要指定格式化模式。
由于您的输入表示时间轴上具有偏离UTC的时刻,我们将其解析为OffsetDateTime
对象。
OffsetDateTime odt = OffsetDateTime.parse( "2013-01-09T19:32:49.103+05:30" );
odt.toString():2013-01-09T19:32:49.103 + 05:30
要获取UTC值中的简单对象,请提取Instant
。这个Instant
类是java.time的基本构建块类。 Instant
类代表UTC中时间轴上的一个时刻,分辨率为nanoseconds(小数部分最多九(9)位)。
您可以将OffsetDateTime
视为Instant
加上ZoneOffset
。
Instant instant = odt.toInstant(); // UTC.
调用toString
时,会生成标准ISO 8601格式的String
对象。最后Z
是Zulu
的缩写,表示UTC。
instant.toString():2013-01-09T14:02:49.103Z
Instant
以各种方式受到限制,例如以各种格式生成字符串时。因此,您可能希望将OffsetDateTime
调整为UTC作为其偏移;换句话说,偏移为零。 ZoneOffset
类保留UTC的常量ZoneOffset.UTC
。
OffsetDateTime odtUtc = odt.withOffsetSameInstant( ZoneOffset.UTC );
您还可以将偏移量(或时区)应用于Instant
。致电atOffset
或atZone
。
Instant
类是java.time的基本构建块类。可能在您的代码中经常使用,因为最佳做法是在UTC中完成大部分工作。
OffsetDateTime odt = instant.atOffset( ZoneOffset.ofHoursMinutes( 5 , 30 ) );
请注意,与UTC的偏移不是时区。时区是偏移量加上过去和现在的一组规则,用于处理Daylight Saving Time (DST)等异常。因此,如果您确实确定了正确的区域,那么时区总是优于仅仅偏移。
以continent/region
的格式指定proper time zone name,例如America/Montreal
,Africa/Casablanca
或Pacific/Auckland
。切勿使用诸如EST
或IST
之类的3-4字母缩写,因为它们不是真正的时区,不是标准化的,甚至不是唯一的(!)。
如果您知道预期的时区,请应用ZoneId
获取ZonedDateTime
个对象。但是,如果没有验证输入数据的来源,就永远不要假设。许多不同的区域可以共享特定的偏移。例如,在我们输入的情况下,今天恰好在印度(+05:30
)和斯里兰卡(Asia/Kolkata
)使用偏移量Asia/Colombo
。这两个时区对于过去,现在或将来的不同异常可能有不同的规则。
ZoneId z = ZoneId.of( "Asia/Kolkata" );
ZonedDateTime zdt = odt.atZoneSameInstant( z );
toString
ZonedDateTime
方法以明智的方式扩展标准ISO 8601格式,方法是附加时区名称。在这种情况下,[Asia/Kolkata]
。
zdt.toString():2013-01-09T19:32:49.103 + 05:30 [亚洲/加尔各答]
java.time框架内置于Java 8及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.Date
,Calendar
和& SimpleDateFormat
现在位于Joda-Time的maintenance mode项目建议迁移到java.time。
要了解详情,请参阅Oracle Tutorial。并搜索Stack Overflow以获取许多示例和解释。规范是JSR 310。
从哪里获取java.time类?
ThreeTen-Extra项目使用其他类扩展java.time。该项目是未来可能添加到java.time的试验场。您可以在此处找到一些有用的课程,例如Interval
,YearWeek
,YearQuarter
和more。
答案 3 :(得分:1)
您只需使用Calendar类即可。请查看下面的摘要:
Calendar calendar = Calendar.getInstance();
calendar.setTimeZone(TimeZone.getTimeZone("GMT"));
calendar.setTimeInMillis(<--time stamp-->);
//calendar.setTime(<--date object of gmt date-->);
SimpleDateFormat sdf = new SimpleDateFormat("MMM dd, yyyy 'at' hh:mm a");
sdf.setTimeZone(TimeZone.getDefault());
String result=sdf.format(calendar.getTime());