使用freezegun,为什么pytz.utc和utcnow()输出不同的日期时间?

时间:2015-07-02 20:09:47

标签: python datetime pytz freezegun

我很困惑为什么使用freezegun冻结时间的函数输出不同的UTC时间,具体取决于是调用datetime.datetime.utcnow()还是datetime.datetime.now(pytz.utc)。我不是说它坏了,只是因为我不明白为什么,而且想知道!

例如,使用此功能:

@freeze_time("2012-01-14 03:21:34", tz_offset=-4)
def test():
    print("utcnow(): %s" % datetime.datetime.utcnow())
    print("pytz.utc: %s" % datetime.datetime.now(pytz.utc))

输出是:

utcnow(): 2012-01-14 03:21:34
pytz.utc: 2012-01-13 23:21:34+00:00

我想第一个是天真的约会时间,但为什么它们不同时代?

(最终为什么我想知道:如果我在我的测试中使用freezegun,并且我在我的代码中使用pytz生成时间进行测试,我想知道它的'正确'行为应该是什么。)

1 个答案:

答案 0 :(得分:0)

这是freezegun中的一个问题,请参见herehere

该问题似乎不会很快解决。最后,我将其用作解决方法:

def freezegun_utc_workaround():
    return datetime.utcnow().replace(tzinfo=pytz.utc)

为此

 datetime.datetime.now(pytz.utc)

也许最好将其包装并手动打补丁。