在日常的代碼中,咱們經常須要與時間打交道。在Python中,與時間處理有關的模塊就包括:time,datetime以及calendar。這篇文章,主要講解time模塊。 html
在開始以前,首先要說明這幾點: python
索引(Index) | 屬性(Attribute) | 值(Values) |
---|---|---|
0 | tm_year(年) | 好比2011 |
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 |
6 | tm_wday(weekday) | 0 - 6(0表示週日) |
7 | tm_yday(一年中的第幾天) | 1 - 366 |
8 | tm_isdst(是不是夏令時) | 默認爲-1 |
接着介紹time模塊中經常使用的幾個函數: 函數
1)time.localtime([secs]):將一個時間戳轉換爲當前時區的struct_time。secs參數未提供,則以當前時間爲準。 spa
>>> time.localtime()
time.struct_time(tm_year=2011, tm_mon=5, tm_mday=5, tm_hour=14, tm_min=14, tm_sec=50, tm_wday=3, tm_yday=125, tm_isdst=0)
>>> time.localtime(1304575584.1361799)
time.struct_time(tm_year=2011, tm_mon=5, tm_mday=5, tm_hour=14, tm_min=6, tm_sec=24, tm_wday=3, tm_yday=125, tm_isdst=0) 線程
2)time.gmtime([secs]):和localtime()方法相似,gmtime()方法是將一個時間戳轉換爲UTC時區(0時區)的struct_time。 orm
>>>time.gmtime()
time.struct_time(tm_year=2011, tm_mon=5, tm_mday=5, tm_hour=6, tm_min=19, tm_sec=48, tm_wday=3, tm_yday=125, tm_isdst=0) htm
3)time.time():返回當前時間的時間戳。 索引
>>> time.time()
1304575584.1361799 進程
4)time.mktime(t):將一個struct_time轉化爲時間戳。 ci
>>> time.mktime(time.localtime())
1304576839.0
5)time.sleep(secs):線程推遲指定的時間運行。單位爲秒。
6)time.clock():這個須要注意,在不一樣的系統上含義不一樣。在UNIX系統上,它返回的是「進程時間」,它是用秒錶示的浮點數(時間戳)。而在WINDOWS中,第一次調用,返回的是進程運行的實際時間。而第二次以後的調用是自第一次調用之後到如今的運行時間。(其實是以WIN32上QueryPerformanceCounter()爲基礎,它比毫秒錶示更爲精確)
1
2
3
4
5
6
7
8
|
importtime
if__name__=='__main__':
time.sleep(1)
print"clock1:%s"%time.clock()
time.sleep(1)
print"clock2:%s"%time.clock()
time.sleep(1)
print"clock3:%s"%time.clock()
|
運行結果:
clock1:3.35238137808e-006
clock2:1.00004944763
clock3:2.00012040636
其中第一個clock()輸出的是程序運行時間
第2、三個clock()輸出的都是與第一個clock的時間間隔
7)time.asctime([t]):把一個表示時間的元組或者struct_time表示爲這種形式:'Sun Jun 20 23:21:05 1993'。若是沒有參數,將會將time.localtime()做爲參數傳入。
>>> time.asctime()
'Thu May 5 14:55:43 2011'
8)time.ctime([secs]):把一個時間戳(按秒計算的浮點數)轉化爲time.asctime()的形式。若是參數未給或者爲None的時候,將會默認time.time()爲參數。它的做用至關於time.asctime(time.localtime(secs))。
>>> time.ctime()
'Thu May 5 14:58:09 2011'
>>> time.ctime(time.time())
'Thu May 5 14:58:39 2011'
>>> time.ctime(1304579615)
'Thu May 5 15:13:35 2011'
9)time.strftime(format[, t]):把一個表明時間的元組或者struct_time(如由time.localtime()和time.gmtime()返回)轉化爲格式化的時間字符串。若是t未指定,將傳入time.localtime()。若是元組中任何一個元素越界,ValueError的錯誤將會被拋出。
格式 | 含義 | 備註 |
---|---|---|
%a | 本地(locale)簡化星期名稱 | |
%A | 本地完整星期名稱 | |
%b | 本地簡化月份名稱 | |
%B | 本地完整月份名稱 | |
%c | 本地相應的日期和時間表示 | |
%d | 一個月中的第幾天(01 - 31) | |
%H | 一天中的第幾個小時(24小時制,00 - 23) | |
%I | 第幾個小時(12小時制,01 - 12) | |
%j | 一年中的第幾天(001 - 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 | 時區的名字(若是不存在爲空字符) | |
%% | ‘%’字符 |
備註:
舉個例子:
>>> time.strftime("%Y-%m-%d %X", time.localtime())
'2011-05-05 16:37:06'
10)time.strptime(string[, format]):把一個格式化時間字符串轉化爲struct_time。實際上它和strftime()是逆操做。
>>> time.strptime('2011-05-05 16:37:06', '%Y-%m-%d %X')
time.struct_time(tm_year=2011, tm_mon=5, tm_mday=5, tm_hour=16, tm_min=37, tm_sec=6, tm_wday=3, tm_yday=125, tm_isdst=-1)
在這個函數中,format默認爲:"%a %b %d %H:%M:%S %Y"。
最後,咱們來對time模塊進行一個總結。根據以前描述,在Python中共有三種表達方式:1)timestamp 2)tuple或者struct_time 3)格式化字符串。
它們之間的轉化如圖所示:
要了解更多,請參考time模塊的官方文檔。