Django 中关于时间、时区的用法

Solid · 2018年12月21日 · 229 次阅读

从 django1.4 以后,存在两个概念:naive timeactive time。简单点讲,naive time就是不带时区的时间,而 active time 就是带时区的时间。

举例来说,使用datetime.datetime.utcnow()、datetime.datetime.now()输出的类似 2018-12-21 13:33:05.649870 的就是不带时区的时间(naive time)。

>>> import datetime
>>> print(datetime.datetime.utcnow())
2018-12-21 13:33:05.649870
>>> print(datetime.datetime.now())
2018-12-21 21:33:21.746027

而使用django.util.timezone.now()输出的类似 +00:00 的时间就是带时区的时间(active time),其中 +00:00 表示的就是时区相对性。

>>> d1 = timezone.now()
>>> d1
datetime.datetime(2018, 12, 21, 13, 44, 15, 651215, tzinfo=<UTC>)
>>> print(d1)
2018-12-21 13:44:15.651215+00:00

UTC时间的概念

此外,还有一个概念是UTC时间。什么是 utc 时间呢?请看以下解释:

协调世界时,又称世界统一时间、世界标准时间、国际协调时间。由于英文(CUT)和法文(TUC)的缩写不同,作为妥协,简称UTC。

中国大陆、中国香港、中国澳门、中国台湾、蒙古国、新加坡、马来西亚、菲律宾、西澳大利亚州的时间与UTC的时差均为+8,也就是UTC+8。

三个方法的区别

那么,第一个问题来了:三个时间datetime.datetime.now()、datetime.datetime.utcnow()与django.util.timezone.now() 有什么区别?

  1. datetime.datetime.now():输出的永远是本地时间(naive time)与配置无任任何关系。
  2. datetime.datetime.utcnow():如果setting中配置 USE_TZ=True 则输出的是UTC时间(naive time),如果setting中配置USE_TZ=False,则该输出时间与datetime.datetime.now()完全相同。
  3. django.util.timezone.now():如果setting中配置 USE_TZ=True 则输出的是UTC时间(active time),如果配置USE_TZ=False,则与datetime.datetime.now()完全相同。

总结一下:在具体应用时,应该先确定是否需要带时区,即 naive time 还是 active time。

关于数据库存储

Django1.4版本之前,对时区毫无概概念,对时间的存取、展示不做任何处理,数据库里存储的通常是本地时间,当然都是 naive time

而Django在1.4版本之后存储如果设置了 USE_TZ=True,则存储到数据库中的时间永远是UTC时间。

共收到0条回复
暂无任何评论
我要评论
登录之后,才能够回复。如果您还没有帐号,请先注册
小甜饼

人的天才只是火花,要想使它成熊熊火焰,哪就只有学习!学习。 —— 高尔基