pytz奇怪的时区问题

Art*_* B. 41 python pytz

>>> import pytz
>>> pytz.timezone('Asia/Hong_Kong')
<DstTzInfo 'Asia/Hong_Kong' LMT+7:37:00 STD>
Run Code Online (Sandbox Code Playgroud)

7小时37分钟的偏移量?这有点奇怪,有没有人遇到同样的问题?

事实上,我之间的行为有所不同

import pytz
from datetime import datetime
hk = pytz.timezone('Asia/Hong_Kong')

dt1 = datetime(2012,1,1,tzinfo=hk)
dt2 = hk.localize(datetime(2012,1,1))
if dt1 > dt2:
   print "Why?"
Run Code Online (Sandbox Code Playgroud)

Mar*_*som 55

多年来,时区和抵消都在变化.pytz创建时区对象时传递的默认区域名称和偏移量是该区域最早可用的区域名称和偏移量,有时它们看起来有点奇怪.当您使用localize的区域连接到一个日期,适当的区域名称和偏移被取代.只需使用datetime构造函数将区域附加到日期就不允许它正确调整.


MrF*_*pes 19

近 10 年后来到这里,我认为值得注意的是,我们现在可以专门利用 Python 3.9+ 标准库来处理时区,而无需“本地化陷阱”。

使用zoneinfo模块来设置和替换 tzinfo,例如:

from datetime import datetime
from zoneinfo import ZoneInfo

hk = ZoneInfo('Asia/Hong_Kong')
print(repr(hk))
# zoneinfo.ZoneInfo(key='Asia/Hong_Kong')

dt1 = datetime(2012,1,1,tzinfo=hk)
print(dt1)
# 2012-01-01 00:00:00+08:00
Run Code Online (Sandbox Code Playgroud)

如果您无法使用替代方案zoneinfo

用户注意事项pandas

  • pandas(v1.4.1)仍在内部使用,并且ZoneInfo时区对象pytz似乎有一些问题


rtp*_*kie 9

虽然我确信时区的历史变化是一个因素,但将 pytz 时区对象传递给 DateTime 构造函数会导致奇怪的行为,即使是自成立以来没有经历任何变化的时区。

import datetime
import pytz 

dt = datetime.datetime(2020, 7, 15, 0, 0, tzinfo= pytz.timezone('US/Eastern'))
Run Code Online (Sandbox Code Playgroud)

产生

2020-07-15 00:00:00-04:56
Run Code Online (Sandbox Code Playgroud)

创建日期时间对象然后对其进行本地化产生了预期的结果

import datetime
import pytz 

dt = datetime.datetime(2020, 7, 15, 0, 0)
dt_local = timezone('US/Eastern').localize(dt)
Run Code Online (Sandbox Code Playgroud)

产生

2020-07-15 00:00:00-04:00
Run Code Online (Sandbox Code Playgroud)

  • 确实如此,但期望 datetime 适当地使用传递的时区对象以及传递给其构造函数的数据参数仍然是合理的。 (3认同)