Django操作model更新时DateTimeField naive datetime错误问题

用Django做东西的时候,更新时间数据时报了错误,错误如下

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,这样问题就解决了。

anyShare分享到:

《Django操作model更新时DateTimeField naive datetime错误问题》有5个想法

发表评论

邮箱地址不会被公开。 必填项已用*标注