總結了最近學習到的time的幾種方法,歸納在這里。
python 中 time 有三種格式:
float,
struct tuple(time.struct_time 或 datetime.datetime),
str
常用的:
float --> struct tuple: time.localtime( float )
struct time tuple --> str: time.strftime(format, struct time tuple)
str --> struct time tuple: time.strptime(str, format)
struct time tuple --> float : time.mktime(struct time tuple)
struct time tuple --> datetime: datetime(*time_tuple[0:6])
float --> datetime: datetime.datetime.fromtimestamp( float )
datetime --> str: datetime.strftime(format, datetime)
str --> datetime: datetime.strptime(str, format)
datetime --> struct time tuple: datetime.timetuple()
Note:
time 是 float 為基礎,小數點后是毫秒,整數部分是秒。(Java 是毫秒,所以,python_time*1000 == Java_time)
datetime 是int, 略去了毫秒部分。datetime tuple 少於 struct_time
Time model
取得時間相關的信息的話,要用到Python time模塊,python time模塊里面有很多非常好用的功能,你可以去官方
文檔了解下,要取的當前時間的話,要取得當前時間的時間戳,時間戳好像是1970年到現在時間相隔的時間。
你可以試下下面的方式來取得當前時間的時間戳:
import time print time.time()
輸出的結果是:
1485337147.3
但是這樣是一連串的數字不是我們想要的結果,我們可以利用time模塊的格式化時間的方法來處理:
time.localtime(time.time())
用time.localtime()方法,作用是格式化時間戳為本地的時間。
輸出的結果是:
time.struct_time(tm_year=2017, tm_mon=1, tm_mday=25, tm_hour=17, tm_min=39, tm_sec=26, tm_wday=2, tm_yday=25, tm_isdst=0)
現在看起來更有希望格式成我們想要的日期和時間了。
time.strftime('%Y-%m-%d',time.localtime(time.time()))
最后用time.strftime()方法,把剛才的一大串信息格式化成我們想要的東西,現在的結果是:
'2017-01-25'
time.strftime里面有很多參數,可以讓你能夠更隨意的輸出自己想要的東西
另外time.strptime轉換字符串為time tuple
>>> time.strptime('2017-01-25', '%Y-%m-%d') time.struct_time(tm_year=2017, tm_mon=1, tm_mday=25, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=2, tm_yday=25, tm_isdst=-1)
time.mktime時間戳
>>> time.strptime('2017-01-25 18:47:16', '%Y-%m-%d %H:%M:%S')
time.struct_time(tm_year=2017, tm_mon=1, tm_mday=25, tm_hour=18, tm_min=47, tm_sec=16, tm_wday=2, tm_yday=25, tm_isdst=-1)
>>> time.mktime(time.strptime('2017-01-25 18:47:16', '%Y-%m-%d %H:%M:%S')) # 生成時間戳
1485341236.0
>>> time.gmtime(1485341236.0) # 轉換時間戳為UTC time tuple
time.struct_time(tm_year=2017, tm_mon=1, tm_mday=25, tm_hour=10, tm_min=47, tm_sec=16, tm_wday=2, tm_yday=25, tm_isdst=0)
>>> time.localtime(1485341236.0) # 轉換時間戳為local time的time tuple
time.struct_time(tm_year=2017, tm_mon=1, tm_mday=25, tm_hour=18, tm_min=47, tm_sec=16, tm_wday=2, tm_yday=25, tm_isdst=0)
>>>
下面是time.strftime的參數:
strftime(format[, tuple]) -> string
將指定的struct_time(默認為當前時間),根據指定的格式化字符串輸出
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 當前時區的名稱
%% %號本身
datetime model
>>> import datetime >>> datetime.datetime.now() # 獲取當前時間 datetime.datetime(2017, 1, 25, 17, 46, 12, 589000) >>> datetime.datetime.today() # 獲取當前時間 datetime.datetime(2017, 1, 25, 17, 47, 47, 523000) >>> datetime.datetime.now().day # 獲取當天日期 25 >>> datetime.datetime.now().year # 獲取當前年份 2017 >>> datetime.datetime.now().date() # 返回date類型 datetime.date(2017, 1, 25) >>> datetime.datetime.now().timetuple() # 返回time結構 time.struct_time(tm_year=2017, tm_mon=1, tm_mday=25, tm_hour=17, tm_min=55, tm_sec=22, tm_wday=2, tm_yday=25, tm_isdst=-1) >>> time.localtime(time.time()) # 一樣返回time結構 time.struct_time(tm_year=2017, tm_mon=1, tm_mday=25, tm_hour=18, tm_min=17, tm_sec=28, tm_wday=2, tm_yday=25, tm_isdst=0) >>> datetime.datetime.now().time() # 返回time類型 datetime.time(18, 17, 53, 381000) >>> datetime.datetime.now().weekday() # 當前星期幾。星期一是0,星期於是6。這里是方法,不是屬性 2 >>> datetime.datetime.now().isoweekday() # 當前星期幾。星期一是1,星期於是7。 這里是方法,不是屬性 3 >>> datetime.datetime.now()-datetime.datetime(2016,1,25,18,17,28,00) # 進行比較運算,返回timedelta類型 datetime.timedelta(366, 244, 60000) >>> datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S") # 轉換成字符串 '2017-01-25 18:22:26' >>> time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(time.time())) # 轉換成字符串
'2017-01-25 18:22:35'
>>> datetime.datetime.strptime("2017-01-25 18:50:16", "%Y-%m-%d %H:%M:%S") # 字符串生成datetime對象
datetime.datetime(2017, 1, 25, 18, 50, 16)