Python中時間格式轉換
在專案中遇到時間格式轉換的問題,由CST形式的string轉為XXXX-XX-XX形式的日期,如:
原來:Thu Jun 22 00:00:00 CST 2017
目標:2017-06-22
一番查詢後,找到了解決方法,思路:利用strptime和strftime方法,先將原本格式的時間轉成時間戳,再利用strftime轉成規定形式的字元
函式:
import time
def cst_to_str(cstTime):
tempTime = time.strptime(cstTime,'%a %b %d %H:%M:%S CST %Y')
resTime = time.strftime('%Y-%m-%d',tempTime)
return resTime
python中時間日期格式化符號:
%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)
%a 本地簡化星期名稱
%A 本地完整星期名稱
%b 本地簡化的月份名稱
%B 本地完整的月份名稱
%c 本地相應的日期表示和時間表示
%j 年內的一天(001-366)
%p 本地A.M.或P.M.的等價符
%U 一年中的星期數(00-53)星期天為星期的開始
%w 星期(0-6),星期天為星期的開始
%W 一年中的星期數(00-53)星期一為星期的開始
%x 本地相應的日期表示
%X 本地相應的時間表示
%Z 當前時區的名稱
%% %號本身
例如:
格式化成2009-03-20 11:45:39形式
time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
格式化成Sat Mar 28 22:24:24 2009形式
time.strftime("%a %b %d %H:%M:%S %Y", time.localtime())
另附calendar模組獲取某個月份天數的方法
import calendar
days = calendar.monthrange(year,month)
如
days = calendar.monthrange(2018,1)
print days
>>>31