Django ——Timezone 處理
Django ——Timezone 處理
https://blog.csdn.net/qq_37049781/article/details/79347278
2018年02月22日 14:50:24 何惜戈 閱讀數:4259Django 中的時區
在現實環境中,存在有多個時區。使用者之間很有可能存在於不同的時區,並且許多國家都擁有自己的一套夏令時系統。所以如果網站面向的是多個時區使用者,只以當前時間為標準開發,便會在時間計算上產生錯誤。
為解決這個此類問題,在程式碼和資料庫中統一使用 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()
- 1
- 2
當開啟時區時,django 使用已知 (aware) 的 datetime 物件儲存本地時間:
from django.utils import timezone
now = timezone.now()
- 1
- 2
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>)
- 1
- 2
- 3
- 4
- 5
- 6
- 7
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>)
- 1
- 2
- 3
- 4
- 5
- 6
- 7
Python 中的 time/datetime
time 模組
time 模組提供各種操作時間的函式
一般有兩種表示時間的方式:
第一種是時間戳的方式 (相對於1970.1.1 00:00:00以秒計算的偏移量),時間戳是唯一的
>>> import time
>>> time.time()
1519270378.989196
- 1
- 2
- 3
第二種以陣列的形式表示即 (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)
- 1
- 2
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
- 1
- 2
- 3
- 4
- 將 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)
- 1
- 2
- 3
- 4
- 5
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)
- 1
- 2
- 3
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)
- 1
- 2
- 3
- 4
- 5
- 6
對時間間隔操作
- 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)
- 1
- 2
格式化程式碼參考表
程式碼 | 作用 | 程式碼 | 作用 | |
---|---|---|---|---|
%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 時區名稱,如果不能得到時區名稱則返回空字元。 | %% | 百分號 |