从 django1.4 以后,存在两个概念:naive time 与 active 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=)
>>> 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() 有什么区别?
datetime.datetime.now():输出的永远是本地时间(naive time)与配置无任任何关系。
datetime.datetime.utcnow():如果setting中配置 USE_TZ=True 则输出的是UTC时间(naive time),如果setting中配置USE_TZ=False,则该输出时间与datetime.datetime.now()完全相同。
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时间。