Django运行时报出的警告while time zone support is active

RuntimeWarning: DateTimeField Customer.updated received a naive datetime (2016-06-19 07:18:21.118000) while time zone support is active

这是一个跟时区有关的问题,错误里说到datetime字段得到一个naive datetime,而不是支持time zone的active datetime
由于USE_TZ设置为True,Django会自动根据所设的时区对时间进行转换

程序中和数据保存的时间都转UTC时间,只有模版渲染时会把时间转为TIME_ZONE所设置的时区的时间

使用datetime.datetime.utcnow()输出的是不带时区的utc时间,称为naive time


>>> from datetime import datetime
>>> datetime.now()
datetime.datetime(2016, 06, 19, 07, 14, 55, 865000)

使用django.utils.timezone.now()输出的是带时区的utc时间,称为active time


>>> from django.utils import timezone
>>> timezone.now()
datetime.datetime(2016, 06, 19, 07, 15, 48, 367000, tzinfo=<UTC>)

如果项目需要根据时区显示时间,那就使用Django的timezone.now()。不需要的话将USE_TZ设置为False即可。

使用带时区的时间,将所有用到datetime.now()的地方改为timezone.now(),并在对应的文件顶部加上from django.utils import timezone,这样问题就解决了。

猜你喜欢

转载自blog.csdn.net/weixin_37887248/article/details/81335441