频道栏目
首页 > 程序开发 > 软件开发 > 其他 > 正文
Django运行时报出的警告while time zone support is active
2018-08-14 15:28:57           
收藏   我要投稿

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=)

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

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

点击复制链接 与好友分享!回本站首页
上一篇:CUBA与Spring区别解析
下一篇:分布式利器Zookeeper:分布式锁
相关文章
图文推荐
点击排行

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站