6

可能重复:
pytz 的奇怪时区问题

这似乎是错误的:

>>> import pytz
>>> z1 = timezone('America/Edmonton')
>>> z2 = timezone('US/Mountain')
>>> z1
<DstTzInfo 'America/Edmonton' LMT-1 day, 16:26:00 STD>
>>> z2
<DstTzInfo 'US/Mountain' MST-1 day, 17:00:00 STD>
>>> pytz.VERSION
'2012f'
>>> 

'America/Edmonton' 和 'US/Eastern' 应该是同一时区 (17:00:00 STD)。更不用说 16:26:00 没有任何意义。

- 更新 -

以上在 Jon Skeet 的回答中是有意义的。但是,当我这样做时,事情变得很奇怪:

>>> d = datetime.now()
>>> d
datetime.datetime(2012, 10, 9, 15, 21, 41, 644706)

我创造了一个天真的约会。由于“美国/埃德蒙顿”我的时区,我尝试手动设置:

>>> d2 = d.replace(tzinfo=timezone('America/Edmonton'))
>>> d2
datetime.datetime(2012, 10, 9, 15, 21, 41, 644706, tzinfo=<DstTzInfo 'America/Edmonton' LMT-1 day, 16:26:00 STD>)

这不应该改变任何东西,因为那是正确的 TZ。然而:

>>> d2.astimezone(timezone('US/Eastern'))
datetime.datetime(2012, 10, 9, 18, 55, 41, 644706, tzinfo=<DstTzInfo 'US/Eastern' EDT-1 day, 20:00:00 DST>)

这应该给我 2 小时的偏移量('US/Eastern' 和 'America/Edmonton' 之间的差异)但它给了我 3 小时 26 分钟(即 2 小时1 小时 26 分钟:D)

插入timezone('US/Mountain')会产生正确的结果astimezone()。使用“美国/埃德蒙顿”创建感知日期时间也将正常工作。

4

2 回答 2

11

pytz的文档明确指出,直接从时区创建日期时间并非在所有情况下都有效,而是指示您执行以下操作:

d2 = timezone('America/Edmonton').localize(d)
于 2012-10-09T22:50:51.847 回答
3

查看 2012c TZDB 数据,这里是美国/埃德蒙顿的规则集:

Zone America/Edmonton    -7:33:52 -       LMT   1906 Sep
                         -7:00    Edm     M%sT  1987
                         -7:00    Canada  M%sT

我不清楚 Python 输出试图向您显示偏移量/名称的日期/时间,但我怀疑它类似于 1900 - 在这种情况下,16:26:00 对 -7 的偏移量有意义: 33:52,它也将与缩写匹配。

所以时区数据没问题是完全可行的,它只是选择显示一个奇怪的日期/时间作为例子。(老实说,时区的字符串输出根本不会显示时间,这对我来说毫无意义......)

于 2012-10-09T21:48:00.653 回答