最佳答案
我需要做的
我有一个不知道时区的日期时间对象,我需要向其添加一个时区,以便能够将其与其他知道时区的日期时间对象进行比较。对于这一遗留案例,我不想将我的整个应用程序转换为不知道时区。
我尝试过什么
首先,演示问题:
Python 2.6.1 (r261:67515, Jun 24 2010, 21:47:49)
[GCC 4.2.1 (Apple Inc. build 5646)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> import datetime
>>> import pytz
>>> unaware = datetime.datetime(2011,8,15,8,15,12,0)
>>> unaware
datetime.datetime(2011, 8, 15, 8, 15, 12)
>>> aware = datetime.datetime(2011,8,15,8,15,12,0,pytz.UTC)
>>> aware
datetime.datetime(2011, 8, 15, 8, 15, 12, tzinfo=<UTC>)
>>> aware == unaware
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: can't compare offset-naive and offset-aware datetimes
首先,我尝试了astimezone:
>>> unaware.astimezone(pytz.UTC)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: astimezone() cannot be applied to a naive datetime
>>>
失败并不奇怪,因为它实际上是在尝试进行转换。替换似乎是更好的选择(根据如何在Python中获得“时区感知”的datetime.today()值?):
>>> unaware.replace(tzinfo=pytz.UTC)
datetime.datetime(2011, 8, 15, 8, 15, 12, tzinfo=<UTC>)
>>> unaware == aware
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: can't compare offset-naive and offset-aware datetimes
>>>
但是正如你所看到的,替换似乎设置了tzinfo,但没有让对象知道。我准备回退到修改输入字符串以在解析它之前有一个时区(如果重要的话,我正在使用dateutil进行解析),但这似乎非常笨拙。
此外,我在Python 2.6和Python 2.7中尝试过,结果相同。
背景
我正在为一些数据文件编写解析器。我需要支持一种旧格式,其中日期字符串没有时区指示器。我已经修复了数据源,但我仍然需要支持遗留数据格式。由于各种业务BS原因,一次性转换遗留数据不是一个选项。虽然总的来说,我不喜欢硬编码默认时区的想法,但在这种情况下,它似乎是最好的选择。我有合理的信心知道所有有问题的遗留数据都是UTC,所以我准备接受在这种情况下默认的风险。