为啥我会得到欧洲/柏林时区 0:53 的偏移量?

Posted

技术标签:

【中文标题】为啥我会得到欧洲/柏林时区 0:53 的偏移量?【英文标题】:Why do I get the offset 0:53 for timezone Europe/Berlin?为什么我会得到欧洲/柏林时区 0:53 的偏移量? 【发布时间】:2018-10-30 18:47:43 【问题描述】:

示例代码

from datetime import datetime, timezone
import pytz

tzstring = 'Europe/Berlin'
t1 = datetime(2016, 6, 16, 2, 0, tzinfo=pytz.timezone(tzstring))
t2 = datetime(2016, 6, 16, 2, 0, tzinfo=timezone.utc).astimezone(pytz.timezone(tzstring))

观察到

print(t1): 2016-06-16 02:00:00+00:53
print(t2): 2016-06-16 04:00:00+02:00

预期

print(t1): 2016-06-16 04:00:00+02:00  # does not match expectation
print(t2): 2016-06-16 04:00:00+02:00  # matches expectation

问题

谁能给我解释一下?

其他问题:

Why doesn't pytz localize() produce a datetime object with tzinfo matching the tz object that localized it? 只要求解释“代码的来源”。我的问题更偏向于:“为什么会这样?” - 我接受的答案很可能会包含一些历史。

【问题讨论】:

Why doesn't pytz localize() produce a datetime object with tzinfo matching the tz object that localized it?的可能重复 另一个答案也说明了为什么它是这个值:LMT。在这么简单的问题中,我真的没有看到大节标题的好处。 这样的原因并不是真正的编程问题。它与history of german timezones有关。 @SeanBreckenridge 啊,太好了! This Wiki article 朝着正确的方向前进!我仍然想念的是当地时间是如何计算的。 【参考方案1】:

我不想说我可以这样解释它,但它记录为不起作用。来自pytz home page:

该库仅支持两种构建本地化时间的方法。首先是使用pytz库提供的localize()方法。这用于本地化一个简单的日期时间(没有时区信息的日期时间)

(示例)

构建本地化时间的第二种方法是使用标准astimezone() 方法转换现有本地化时间。

(示例)

不幸的是,对于许多时区,使用标准日期时间构造函数的 tzinfo 参数对 pytz “不起作用”。

>>> datetime(2002, 10, 27, 12, 0, 0, tzinfo=amsterdam).strftime(fmt)
'2002-10-27 12:00:00 LMT+0020'

但对于没有夏令时转换的时区是安全的,例如 UTC

我怀疑 pytz 中的时区表示与 datetime 构造函数使用的内容不兼容。

与其追逐确切的细节,我认为接受它不起作用并使用建议的替代方案更实际。

【讨论】:

(问题的答案我将这个问题标记为解释它的副本) @SeanBreckenridge 这个答案对你来说可能很清楚,但它肯定不适合我。是的,它在 tz 数据源中。但是为什么会这样呢?

以上是关于为啥我会得到欧洲/柏林时区 0:53 的偏移量?的主要内容,如果未能解决你的问题,请参考以下文章

pytz 时区的 STD 偏移量

获取节点中特定时区的 UTC 偏移量和 DST 信息? [复制]

使用 Joda-Time 获取给定日期和时区的 UTC 偏移量

如何确定服务器时区的 UTC 偏移量?

为啥我需要 00 时区偏移量才能在 d3v4 中正确显示值?

从 UTC 偏移量获取时区名称