python中的time模組
阿新 • • 發佈:2018-12-15
time模組--時間獲取和轉換
time模組提供各種時間相關的功能
與時間相關的模組有:time,datetime,calendar
必要說明:
這個模組的功能不是適用於所有的平臺
這個模組中定義的大部分函式是呼叫C平臺上的同名函式實現
一些術語和約定的解釋:
1.時間戳(timestamp)的方式:通常來說,時間戳表示的是從1970年1月1日開始按秒計算的偏移量(time.gmtime(0))此模組中的函式無法處理1970紀元年以前的時間或太遙遠的未來(處理極限取決於C函式庫,對於32位系統而言,是2038年) 2.UTC(Coordinated Universal Time,世界協調時)也叫格林威治天文時間,是世界標準時間.在我國為UTC+8 3.DST(Daylight Saving Time)即夏令時 4.一些實時函式的計算精度可能不同
時間元祖(time.struct_time)
gmtime(),localtime()和strptime()以時間元祖(struct_time)的形式返回
索引值(index) | 屬性(Attribute) | 值(Values) |
---|---|---|
0 | tm_year(年) | (例如:2015) |
1 | tm_mon(月) | 1-12 |
2 | tm_mday(日) | 1-31 |
3 | tm_hour(時) | 0-23 |
4 | tm_min(分) | 0-59 |
5 | tm_sec(秒) | 0-61(60代表閏秒,61是基於歷史原因保留) |
6 | tm_wday(星期幾) | 0-6(0表示星期一) |
7 | tm_yday(一年中的第幾天) | 1-366 |
8 | tm_isdst(是否為夏令時) | 0,1,-1(-1代表夏令時) |
time.altzone
返回格林威治西部的夏令時地區的偏移秒數,如果該地區在格林威治東部會返回負值(如西歐,包括英國),對夏令時啟用地區才能使用
time.asctime([t])
接受時間元組並返回一個可讀的形式"Tue May 30 17:17:30 2017"(2017年5月30日週二17時17分30秒)的24個字元的字串
time.clock()
用以浮點數計算的秒數返回當前的CPU時間,用來衡量不同程式的耗時,比time.time()更有用 python3.3以後不被推薦使用,該方法依賴作業系統,建議使用per_counter(返回系統執行時間)或process_time(返回程序執行時間)代替
time.ctime([secs])
作用相當於asctime(localtime(secs)),未給引數相當於asctime()
time.gmtime([secs])
接收時間輟(1970紀元年後經過的浮點秒數)並返回格林威治天文時間下的時間元組t(t.tm_isdst始終為0)
time.daylight
如果夏令時被定義,則該值為非零
time.localtime([secs])
接收時間輟(1970紀元年後經過的浮點秒數)並返回當地時間下的時間元組t(t.tm_isdst可取為0或1,取決於當地當時是不是夏令時)
time.mktime(t)
接受時間元組並返回時間輟(1970紀元年後經過的浮點秒數)
time.perf_counter()
返回計時器的精準時間(系統的執行時間),包含整個系統的睡眠時間.由於返回值的基準點是未定義的,所以,只有連續呼叫的結果之間的差才是有效的
time.process_time()
返回當前程序執行CPU的時間總和,不包含睡眠時間.由於返回值的基準點是未定義的,所以只有連續呼叫的結果之間的差才是有效的
time.sleep(secs)
推遲呼叫執行緒的執行,secs的單位是秒
time.strftime(format[,t])
把一個代表時間的元組或者struct_time(如由time.localtime()和time.gmtime()返回)轉化為格式化的時間字串.如果t未指定,將傳入time.localtime(),如果元組中任命一個元素越界,將會丟擲ValueError異常
format格式如下:
%a 本地(local)簡化星期名稱
%A 本地完整星期名稱
%b 本地簡化月份名稱
%B 本地完整月份名稱
%c 本地相應的日期和時間表示
%d 一個月中的第幾天(01-31)
%H 一天中的第幾個小時(24小時制,00-23)
%l 一天中的第幾個小時(12小時制,01-12)
%j 一年中的第幾天(01-366)
%m 月份(01-12)
%M 分鐘數(00-59)
%p 本地am或者pm的相應符
%S 秒(01-61)
%U 一年中的星期數(00-53,星期天是一個星期的開始,第一個星期天之前的所有天數都放在第0周)
%w 一個星期中的第幾天(0-6,0是星期天)
%W 和%U基本相同,不同的是%W以星期一為一個星期的開始
%x 本地相應日期
%X 本地相應時間
%y 去掉世紀的年份(00-99)
%Y 完整的年份
%z 用+HHMM或者-HHMM表示距離格林威治的時區偏移(H代表十進位制的小時數,M代表十進位制的分鐘數)
%Z 時區的名字(如果不存在為空字元)
%% %號本身
%p只有與%I配合使用才有效果
當使用strptime()函式時,只有當在這年中的週數和天數被確定的時候%U和%W才會被計算
time.strptime(string[,format])
把一個格式化時間字串轉化為struct_time,實際上它和strftie()是逆操作
time.time()
返回當前時間的時間戳(1970元年後的浮點秒數)
time.timezone()
是當地時區(未啟動夏令時)距離格林威治的偏移秒數(美洲>0,歐洲大部分,亞洲,非洲<=0)
time.tzname
包含兩個字串的元組,第一是當地夏令時區的名稱,第二是當地的DST時區的名稱