1. 程式人生 > >【Django】Django中datetime的處理(strftime/strptime)

【Django】Django中datetime的處理(strftime/strptime)

strftime<將date,datetime,timezone.now()型別處理轉化為字串型別>

  strftime()函式是用來格式化一個日期、日期時間和時間的函式,支援date、datetime、time等類,把這些時間通過格式字元要求格式為字串表示。

import datatime
datatime.datatime.now()

或者

from datatime import datatime
datatime.now()

我的輸出轉化格式

strftime('%Y-%m-%d %H:%I:%S')

效果類似於2018-07-02 23:18:20這樣.

strptime<將字串處理轉換成期望型別的資料>

  strptime()函式就是從字串表示的日期時間按格式化字串要求轉換為相應的日期時間。

d2 = datetime.strptime('2018-03-02 17:41:20', '%Y-%m-%d %H:%M:%S')

轉化對照的格式: 
轉成字串

%y 兩位數的年份表示(00-99)
%Y 四位數的年份表示(000-9999)
%m 月份(01-12)
%d 月內中的一天(0-31)
%H 24小時制小時數(0-23)
%I 12小時制小時數(01-12)  十二小時制
%M 分鐘數(00=59)
%S 秒(00-59) 

遇到的兩個bug:

一:顯示時間和資料庫不一致的bug:

  曾經遇到過這樣的一個問題,從資料庫取出來的時間和前端顯示時間不一致的問題.後來經過多出輸出時間各處轉換的資訊,最後發現,因為之前寫程式碼的同事,使用了這樣的

one['time'] = one['time'].strftime('%Y-%m-%d %H:%I:%S')

%I是十二小時制的轉換形式.這樣轉換格式的時候,雖然不會報錯,可是輸出的結果會和資料庫的不一致,資料庫是以24小時為單位記錄的時間.

二:datetime.datetime(2018, 2, 2, 18, 25, 29, tzinfo=) is not JSON serializable

出現這樣的錯誤資訊..

datetime.datetime(2018, 2, 2, 18, 25, 29, tzinfo=<UTC>) is not JSON serializable

 這是出現在將datetime資料直接放在字典裡轉化為json格式資料返回給前端的時候出現的錯誤資訊.不能直接將datetime轉化為json..

解決辦法是:可以使用strftime進行序列化,如下面的方法:

record_time=record_time.strftime("%Y-%m-%d %H:%M:%S")

用這樣的方法將record_time轉化成str型別,就可以了.