1. 程式人生 > >python中的time模組

python中的time模組

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時區的名稱