詳解Python編程中time模組的使用

來源:互聯網
上載者:User
一、簡介

time模組提供各種操作時間的函數
說明:一般有兩種表示時間的方式:
第一種是時間戳記的方式(相對於1970.1.1 00:00:00以秒計算的位移量),時間戳記是惟一的
第二種以數組的形式表示即(struct_time),共有九個元素,分別表示,同一個時間戳記的struct_time會因為時區不同而不同

  • year (four digits, e.g. 1998)
  • month (1-12)
  • day (1-31)
  • hours (0-23)
  • minutes (0-59)
  • seconds (0-59)
  • weekday (0-6, Monday is 0)
  • Julian day (day in the year, 1-366)
  • DST (Daylight Savings Time) flag (-1, 0 or 1) 是否是夏令時
  • If the DST flag is 0, the time is given in the regular time zone;
  • if it is 1, the time is given in the DST time zone;
  • if it is -1, mktime() should guess based on the date and time.

夏令時介紹:http://baike.baidu.com/view/100246.htm

UTC介紹:http://wenda.tianya.cn/wenda/thread?tid=283921a9da7c5aef&clk=wttpcts

二、函數介紹

1.asctime()

asctime([tuple]) -> string

將一個struct_time(預設為當時時間),轉換成字串
Convert a time tuple to a string, e.g. ‘Sat Jun 06 16:26:11 1998'.
When the time tuple is not present, current time as returned by localtime() is used.

2.clock()

clock() -> floating point number
該函數有兩個功能,
在第一次調用的時候,返回的是程式啟動並執行實際時間;
以第二次之後的調用,返回的是自第一次調用後,到這次調用的時間間隔

註:
在Xinux上使用 time.time() 而在windows中使用time.clock()可以得到更高的精度.
Xinux和Win在實現系統時鐘的不同。time.clock()是調用的系統時鐘實現,而兩個平台又有所不同。
主要問題在於Xinux時鐘切換策略:jiffy的實現,因為核心時鐘的切換不是連續的而是間隔一段時間(一般而言在1ms~10ms之間)之後才變化, 所以如果是在Xinux中的兩次耗時較短的調用,通過time.clock()得到的結果是一樣的。

3.sleep(…)

sleep(seconds)
線程延遲指定的時間運行,經過測試,單位為秒
樣本:

import time if __name__ == '__main__':   time.sleep(3)   print "clock1: %s" % time.clock()   # print "local time: %s" % time.localtime()   print str(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime()))   time.sleep(3)   print "clock2: %s" % time.clock()   # print "local time: %s" % time.localtime()   print str(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime()))   time.sleep(3)   print "clock3: %s" % time.clock()   # print "local time: %s" % time.localtime()   print str(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime()))

結果

clock1: 0.0206782015-08-09 00:18:31clock2: 0.0208912015-08-09 00:18:34clock3: 0.0210682015-08-09 00:18:37

4.ctime(…)

ctime(seconds) -> string
將一個時間戳記(預設為目前時間)轉換成一個時間字串
例如:

time.ctime()

輸出為:

'Sat Mar 28 22:24:24 2009′

5.gmtime(…)

gmtime([seconds]) -> (tm_year, tm_mon, tm_day, tm_hour, tm_min,tm_sec, tm_wday, tm_yday, tm_isdst)
將一個時間戳記轉換成一個UTC時區(0時區)的struct_time,如果seconds參數未輸入,則以目前時間為轉換標準

6.localtime(…)

localtime([seconds]) -> (tm_year,tm_mon,tm_day,tm_hour,tm_min,tm_sec,tm_wday,tm_yday,tm_isdst)
將一個時間戳記轉換成一個當前時區的struct_time,如果seconds參數未輸入,則以目前時間為轉換標準

7.mktime(…)

mktime(tuple) -> floating point number
將一個以struct_time轉換為時間戳記

8.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 當前時區的名稱
  • %% %號本身
print str(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime()))

 2015-08-09 00:18:37

9.strptime(…)

strptime(string, format) -> struct_time
將時間字串根據指定的格式化符轉換成數組形式的時間
例如:
2009-03-20 11:45:39 對應的格式化字串為:%Y-%m-%d %H:%M:%S
Sat Mar 28 22:24:24 2009 對應的格式化字串為:%a %b %d %H:%M:%S %Y

10.time(…)

time() -> floating point number
返回目前時間的時間戳記(1970紀元後經過的浮點秒數)

三、常用命令

1.python擷取目前時間

time.time() 擷取目前時間戳
time.localtime() 目前時間的struct_time形式
time.ctime() 目前時間的字串形式

print time.time() print time.localtime() print time.ctime()

結果為:

1439051479.08time.struct_time(tm_year=2015, tm_mon=8, tm_mday=9, tm_hour=0, tm_min=31, tm_sec=19, tm_wday=6, tm_yday=221, tm_isdst=0) Sun Aug 9 00:31:19 2015

2.python格式化字串

格式化成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())

3.將格式字串轉換為時間戳記

a = “Sat Mar 28 22:24:24 2009″

b = time.mktime(time.strptime(a,”%a %b %d %H:%M:%S %Y”))

ps:
瞭解這一塊主要是想用time來計算我程式中關鍵既不的已耗用時間,所以更多整理這部分內容。至於時間的轉化等,後續用得著的時候再來整理。

四、使用time模組計算代碼執行效率的精度測試

#python中使用time模組計算代碼執行效率 #測試用time.time()和time.clock()使用精度  import sys import time import timeit default_timer = None  if sys.platform == "win32": # On Windows, the best timer is time.clock()   default_timer = time.clock else: # On most other platforms the best timer is time.time()   default_timer = time.time print default_timer timeIn= time.clock() for i in range(100):   n=i timeUse = time.clock()-timeIn print timeUse  timeIn = time.time() for i in range(100):   n=i timeUse = time.time()-timeIn print timeUse  timeIn = timeit.default_timer() for i in range(100):   n=i timeUse = timeit.default_timer()-timeIn print timeUse     #該段代碼在windows下結果如下 >>>  4.07873067161e-005 0.0 3.5758734839e-005  #因為time.clock() 返回的是處理器時間,而因為 Unix 中 jiffy 的緣故,所以精度不會太高。 #因此,在Windows 系統中,建議使用 time.clock(),在Unix 系統中,建議使用 time.time(), #而使用timeit代替 time,就可以實現跨平台的精度性,使用timeit.default_timer()函數來擷取時間 
  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.