我使用简单的日期格式来允许用户指定他们在哪个时区发送数据:
DateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss,z");
这很好用: e.g。
df.parse("2009-05-16 11:07:41,GMT");
但是,如果有人总是在伦敦时间发送时间(即考虑到夏令时),那么要添加的approriate时区字符串是什么? 例如这不起作用:
df.parse("2009-05-16 11:07:41,Western European Time");
System.out.println(date);
Sat May 16 12:07:41 BST 2009
我希望将英国时间与夏令时相匹配。
感谢。
答案 0 :(得分:5)
在夏令时中,它是BST
。在今年剩下的时间里,它是GMT
。
我建议您使用通用名称(全年),即Europe/London
。你可以使用这样的东西:
String userInput = "2009-05-16 11:07:41,Europe/London";
String[] tokens = userInput.split(",");
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
df.setTimeZone(TimeZone.getTimeZone(tokens[1]));
System.out.println(df.parse(tokens[0]));
这种情况下的输出是:
Sat May 16 11:07:41 GMT+01:00 2009
答案 1 :(得分:0)
那么您的问题究竟是什么 - 您应该使用TimeZone
的ID?以下将打印所有可用时区标识符的列表:
for (String id : TimeZone.getAvailableIDs()) {
System.out.println(id);
}
答案 2 :(得分:0)
我认为不可能单独使用SimpleDateFormat做你想做的事情。 TimeZone.parse(String)仅接受时区,而不接受时区ID,例如:
Time Zone ID Time Zone (Winter) Time Zone (Summer)
-------------------------------------------------------------
Europe/London GMT BST
如果解析(...)接受欧洲/伦敦,那么春天将有一个小时不是有效的欧洲/伦敦时间,而秋天的一个小时将映射到两个UTC时间。
我认为您可以做的最好是遵循Bruno Rothgiesser的建议,但是您可以接受时区ID作为单独的用户输入,或者执行额外的字符串处理步骤以将时区ID与用户输入字符串分开,并用它来确定用户是否可能意味着GMT或BST。用户的区域设置可能是一种更好的方法来计算他/她的意思 - 虽然这个想法涉及一些假设。
“用户可能意味着什么”算法必须处理两种特殊情况 - 你可以使用TimeZone.inDaylightTime(Date)和userTime +/- 1小时来计算出你是否有其中一种。