我在PostgreSQL中有一个时区感知timestamptz字段。当我从表中提取数据时,我想减去现在的时间,这样我就可以得到它的年龄。
我遇到的问题是datetime.datetime.now()和datetime.datetime.utcnow()似乎都返回不知道时区的时间戳,这导致我得到这个错误:
TypeError: can't subtract offset-naive and offset-aware datetimes
是否有办法避免这种情况(最好不使用第三方模块)。
编辑:谢谢你的建议,但试图调整时区似乎给我错误。所以我将在PG中使用不考虑时区的时间戳,并且总是插入using:
NOW() AT TIME ZONE 'UTC'
这样,默认情况下我的所有时间戳都是UTC(尽管这样做更烦人)。
你不需要性病资料库以外的任何东西
datetime.datetime.now().astimezone()
如果你只是更换了时区,它不会调整时间。如果你的系统已经是UTC,那么.replace(tz='UTC')就可以了。
>>> x=datetime.datetime.now()
datetime.datetime(2020, 11, 16, 7, 57, 5, 364576)
>>> print(x)
2020-11-16 07:57:05.364576
>>> print(x.astimezone())
2020-11-16 07:57:05.364576-07:00
>>> print(x.replace(tzinfo=datetime.timezone.utc)) # wrong
2020-11-16 07:57:05.364576+00:00
正确的解决方案是添加时区信息,例如,在Python 3中获取当前时间作为感知datetime对象:
from datetime import datetime, timezone
now = datetime.now(timezone.utc)
在较旧的Python版本中,你可以自己定义utc tzinfo对象(来自datetime docs的例子):
from datetime import tzinfo, timedelta, datetime
ZERO = timedelta(0)
class UTC(tzinfo):
def utcoffset(self, dt):
return ZERO
def tzname(self, dt):
return "UTC"
def dst(self, dt):
return ZERO
utc = UTC()
然后:
now = datetime.now(utc)