Django 中的Timezone 处理操作
Django 中的时区
在现实环境中,存在有多个时区。用户之间很有可能存在于不同的时区,并且许多国家都拥有自己的一套夏令时系统。所以如果网站面向的是多个时区用户,只以当前时间为标准开发,便会在时间计算上产生错误。
为解决这个此类问题,在代码和数据库中统一使用 UTC 时间,仅在与最终用户进行交互时使用本地时间是一个很好的办法
Django 默认关闭时区支持,开启时区支持,需要在 settings 中设置 USE_TZ = True 。最好同时安装 pytz 模块(pip install pytz) 。
Naive 和 Aware 类型的 datetime 对象
Python 的 datatime.datetime对象有一个 tzinfo 属性,该属性是 datetime.tzinfo 子类的一个实例,他被用来存储时区信息。当某个 datetime 对象的 tzinfo 属性被设置并给出一个时间偏移量时,我们称该 datetime 对象是 aware (已知) 的。否则称其为 naive (原生) 的。
可以使用 is_aware() 和 is_naive() 函数来判断某个 datetime 对象是 aware 类型或 naive 类型。
当关闭时区时,django 使用原生的 datetime 对象保存本地时间:
import datetime now = datetime.datetime.now()
当开启时区时,django 使用已知 (aware) 的 datetime 对象存储本地时间:
from django.utils import timezone now = timezone.now()
Django 和 Python 中的 Timezone 处理
Django 中的 timezone
from django.utils import timezone >>> now = timezone.now() >>> now datetime.datetime(2018, 2, 22, 3, 13, 2, 383795, tzinfo=<UTC>) >>>new = timezone.localtime(now) >>>new datetime.datetime(2018, 2, 22, 11, 13, 2, 383795, tzinfo=<DstTzInfo 'Asia/Shanghai' CST+8:00:00 STD>)
Python 中的 datetime
>>>import datetime,pytz >>>t = datetime.datetime.now() >>>t datetime.datetime(2018, 2, 22, 11, 18, 15, 623160) >>>new_t = t.replace(tzinfo=(pytz.timezone('Asia/Shanghai'))) >>>new_t datetime.datetime(2018, 2, 22, 11, 18, 15, 623160, tzinfo=<DstTzInfo 'Asia/Shanghai' LMT+8:06:00 STD>)
Python 中的 time/datetime
time 模块
time 模块提供各种操作时间的函数
一般有两种表示时间的方式:
第一种是时间戳的方式 (相对于1970.1.1 00:00:00以秒计算的偏移量),时间戳是唯一的
>>> import time >>> time.time() 1519270378.989196
第二种以数组的形式表示即 (struct_time) ,共有九个元素,分别表示,同一个时间戳的 struct_time 会因为时区不同而不同
>>> time.localtime() time.struct_time(tm_year=2018, tm_mon=2, tm_mday=22, tm_hour=11, tm_min=38, tm_sec=45, tm_wday=3, tm_yday=53, tm_isdst=0)
gmtime() 和 mktime() 可以将两种时间表示方法自由转换
>>> time.gmtime(time.time()) time.struct_time(tm_year=2018, tm_mon=2, tm_mday=22, tm_hour=11, tm_min=38, tm_sec=45, tm_wday=3, tm_yday=53, tm_isdst=0) >>> time.mktime(time.localtime()) 1519270378.989196
将 struct_time 类型与字符型自由转换 *
>>> time1 = time.strftime("%Y-%m-%d",time.localtime()) >>> time1 '2018-02-22' >>> time2 = time.strptime(time1,"%Y-%m-%d") time.struct_time(tm_year=2018, tm_mon=2, tm_mday=22, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=3, tm_yday=53, tm_isdst=0)
datetime 模块
datetime 模块提供多个由于操作日期时间函数
datetime 模块中定义的类:
datetime.date: 表示日期的类。常用的属性有 year,month,day;
datetime.time: 表示时间的类。常用的属性有 hour,minute,second,microsecond;
datetime.datetime: 表示日期时间。
datetime.timedelta: 表示时间间隔,即两个时间点之间的长度。
datetime.tzinfo:与时区有关的相关信息。
>>> import datetime >>> datetime.datetime.now() datetime.datetime(2018, 2, 22, 11, 18, 15, 623160)
datetime类型与字符串类型相互转换
>>> today = datetime.datetime.now().strftime("%Y-%m-%d") >>> today 2018-02-22 >>> today2 = datetime.datetime.strptime(today,"%Y-%m-%d") >>> today2 datetime.datetime(2018, 2, 22, 0, 0)
对时间间隔操作
datetime2 = datetime1 + timedelta #日期加上一个间隔,返回一个新的日期对象
datetime2 = datetime1 - timedelta #日期隔去间隔,返回一个新的日期对象
timedelta = date1 - date2 #两个日期相减,返回一个时间间隔对象
time 与 datetime 之间的相互转换
–date.fromtimestamp(timestamp):根据给定的时间戳,返回一个date对象
>>> datetime.datetime.fromtimestamp(time.time()) datetime.datetime(2018, 2, 22, 14, 44, 847842)
格式化代码参考表
代码 | 作用 | 代码 | 作用 | |
---|---|---|---|---|
%a | 星期几的简写 | %A | 星期几的全称 | |
%b | 月分的简写 | %B | 月份的全称 | |
%c | 标准的日期的时间串 | %C | 年份的后两位数字 | |
%d | 十进制表示的每月的第几天 | %D | 月/天/年 | |
%e | 在两字符域中,十进制表示的每月的第几天 | %F | 年-月-日 | |
%g | 年份的后两位数字,使用基于周的年 | %G | 年分,使用基于周的年 | |
%h | 简写的月份名 | %H | 24小时制的小时 | |
%I | 12小时制的小时 | %j | 十进制表示的每年的第几天 | |
%m | 十进制表示的月份 | %M | 十时制表示的分钟数 | |
%n | 新行符 | %p | 本地的AM或PM的等价显示 | |
%r | 12小时的时间 | %R | 显示小时和分钟:hh:mm | |
%S | 十进制的秒数 | %t | 水平制表符 | |
%T | 显示时分秒:hh:mm:ss | %u | 每周的第几天,星期一为第一天 (值从0到6,星期一为0) | |
%U | 第年的第几周,把星期日做为第一天(值从0到53) | %V | 每年的第几周,使用基于周的年 | |
%w | 十进制表示的星期几(值从0到6,星期天为0) | %W | 每年的第几周,把星期一做为第一天(值从0到53) | |
%x | 标准的日期串 | %X | 标准的时间串 | |
%y | 不带世纪的十进制年份(值从0到99) | %Y | 带世纪部分的十制年份 | |
%z | ,%Z 时区名称,如果不能得到时区名称则返回空字符。 | %% | 百分号 |
补充:Django里面timezone.now()转时间戳/秒数的属性
Django 里timezone对象连度娘都不知道的使用技巧
今天碰到一个需求是:
从MySQL中取出一个时间字段存入redis,在前端发起请求后,将该时间字段与当前时间的差值(s)响应给前端以便于前端用作倒计时。
这里呢整个项目使用的是django框架,django在模型层定义时间字段的时候,使用的是datatimefiled(defult=timezone.now),这里存到数据库里面的是字符串,但是如果你是用django的方式取出来:Model.object.get(…………),那么你实际取到的是一个时间对象,而不是时间字符串,这个时间对象其实就是python里面的timedelta对象。
这个对象就很厉害了,它可以让你在看起来像是某年某月某天这样字符串的形式上直接做加减运算,比如,从reids里取出来的时间对象可以直接和timezone.now()相减,得出预定时间和当前时间的差值,而且这个差值还是一个时间对象,
print('========================:',cache.get('seckill_time'),'===============',timezone.now()) timeout = cache.get('seckill_time') - timezone.now() # type:timedelta print(timeout)
cache.get(‘seckill_time') 是从redis里面取出的时间对象
这个时间对象之所以能够直接进行加减法运算,是因为它重写了python父类里面的加减法函数,当然它还重写了很多基本运算函数,包括比较大小什么的,具体ALT+左键一点就能看见,这里看一下另外两个函数:seconds和microseconds,效果很明显,一个是忽略天数之后把剩余时间转换成秒,一个是取秒之后的小数
timeout = cache.get('seckill_time') - timezone.now() # type:timedelta print(timeout) print(timeout.seconds) print(timeout.microseconds) -------------------------------------- 1 day, 0:37:35.099737 2255 99737
以上为个人经验,希望能给大家一个参考,也希望大家多多支持猪先飞。如有错误或未考虑完全的地方,望不吝赐教。
相关文章
Django def clean()函数对表单中的数据进行验证操作
这篇文章主要介绍了Django def clean()函数对表单中的数据进行验证操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-07-09- 这篇文章主要介绍了在Django中使用MQTT的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-05-10
解决导入django_filters不成功问题No module named 'django_filter'
这篇文章主要介绍了解决导入django_filters不成功问题No module named 'django_filter',具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-07-15- 本文主要介绍了Django项目连接MongoDB的三种方法,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-09-27
详解如何使用Docker部署Django+MySQL8开发环境
这篇文章主要介绍了详解如何使用Docker部署Django+MySQL8开发环境,文中通过示例代码以及图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧...2020-07-19- 这篇文章主要介绍了Django 解决由save方法引发的错误,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-05-21
- 这篇文章主要介绍了django前端页面下拉选择框默认值设置方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-08-10
- 这篇文章主要介绍了django数据模型中null和blank的区别说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-09-03
- 这篇文章主要介绍了Django表单外键选项初始化的问题及解决方法,需本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,要的朋友可以参考下...2021-04-29
Django开发RESTful API实现增删改查(入门级)
这篇文章主要介绍了Django开发RESTful API实现增删改查(入门级),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-05-10- 这篇文章主要给大家介绍了关于使用AJAX和Django获取数据的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-10-25
- 这篇文章主要介绍了Django-ORM-连表正反操作,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-06-13
- 这篇文章主要介绍了django ajax发送post请求的两种方法,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下...2020-04-30
Django获取model中的字段名和字段的verbose_name方式
这篇文章主要介绍了Django获取model中的字段名和字段的verbose_name方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-05-20- 这篇文章主要介绍了django中url映射规则和服务端响应顺序的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-05-10
- 在本篇文章里小编给大家整理的是一篇关于Django后台管理系统的图文使用教学内容,需要的朋友们参考下。...2020-04-22
- 本文总结了如何获得SSL证书并给Django项目配置HTTPS,建议先收藏再阅读,将来有一天你很可能会用到它。...2021-05-01
- 这篇文章主要介绍了django 连接数据库出现1045错误的解决方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-05-15
- 这篇文章主要介绍了Python Django搭建文件下载服务器的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-05-10
Django数据库迁移报错InconsistentMigrationHistory
最近在使用Django,学习了一下Django数据库迁移,在执行迁移命令时,突然报错,本文就总结了一下原因,感兴趣的小伙伴们可以参考一下...2021-05-31