如何在Python中使用timeit模塊-創(chuàng)新互聯(lián)

本篇文章給大家分享的是有關(guān)如何在Python中使用timeit模塊,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。

創(chuàng)新互聯(lián)建站2013年至今,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元陽(yáng)新做網(wǎng)站,已為上家服務(wù),為陽(yáng)新各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:028-86922220

一、使用 timeit() 函數(shù)測(cè)試運(yùn)行時(shí)間

1. 準(zhǔn)備測(cè)試函數(shù)

先寫兩個(gè)函數(shù),一個(gè)函數(shù)是從列表頭部添加數(shù)據(jù),另一個(gè)函數(shù)是從列表尾部添加數(shù)據(jù)。

# coding=utf-8
def insert_time_test():
  insert_list = list()
  for i in range(10):
    insert_list.insert(0, i)
def append_time_test():
  append_list = list()
  for i in range(10):
    append_list.append(i)
if __name__ == '__main__':
  import timeit

2. timeit(stmt="pass", setup="pass", timer=default_timer, number=default_number) 函數(shù)介紹

timeit() 函數(shù)有四個(gè)參數(shù),每個(gè)參數(shù)都是關(guān)鍵字參數(shù),都有默認(rèn)值。

stmt:傳入需要測(cè)試時(shí)間的代碼,可以直接傳入代碼表達(dá)式或單個(gè)變量,也可以傳入函數(shù)。傳入函數(shù)時(shí)要在函數(shù)名后面加上小括號(hào),讓函數(shù)執(zhí)行,如 stmt = ‘func()'  。

setup:傳入 stmt 的運(yùn)行環(huán)境,如 stmt 中使用到的參數(shù)、變量,要導(dǎo)入的模塊等,如 setup = ‘from __main__ import func'。可以寫一行語(yǔ)句,也可以寫多行語(yǔ)句,寫多行語(yǔ)句時(shí)用分號(hào)隔開。

如果 stmt 和參數(shù) setup 參數(shù)不傳值,那么就失去了測(cè)試的意義,所以這兩個(gè)參數(shù)是必要的。

timer: timer 參數(shù)是當(dāng)前操作系統(tǒng)的基本時(shí)間單位,默認(rèn)會(huì)根據(jù)當(dāng)前運(yùn)行環(huán)境的操作系統(tǒng)自動(dòng)獲取(源碼中已經(jīng)定義),保持默認(rèn)即可。

number:要測(cè)試的代碼的運(yùn)行次數(shù),默認(rèn)1000000(一百萬(wàn))次,對(duì)于耗時(shí)的代碼,運(yùn)行太多次會(huì)花很多時(shí)間,可以自己修改運(yùn)行次數(shù)。

3. 測(cè)試函數(shù)的運(yùn)行時(shí)間

現(xiàn)在使用 timeit() 來(lái)測(cè)試上面兩個(gè)函數(shù)的運(yùn)行時(shí)間。

  insert_time_timeit = timeit.timeit(stmt='insert_time_test()', 
                    setup='from __main__ import insert_time_test')
  print('insert_time_timeit: ', insert_time_timeit)
  append_time_timeit = timeit.timeit(stmt='append_time_test()', 
                    setup='from __main__ import append_time_test')
  print('append_time_timeit: ', append_time_timeit)

運(yùn)行結(jié)果:

('insert_time_timeit: ', 2.9112871)
('append_time_timeit: ', 1.8884124999999998)

可以看到,在列表頭部添加數(shù)據(jù)的時(shí)間比在列表尾部添加數(shù)據(jù)的時(shí)間長(zhǎng)。

4. 測(cè)試代碼(表達(dá)式)的運(yùn)行時(shí)間

繼續(xù)使用 timeit() 測(cè)試上面代碼的運(yùn)行時(shí)間,只是這次是直接將代碼傳入到參數(shù)中,而不是傳入函數(shù)。

  insert_time_timeit = timeit.timeit(stmt='list(insert_list.insert(0, i) for i in init_list)',
                    setup='insert_list=list();init_list=range(10)',
                    number=100000)
  print('insert_time_timeit: ', insert_time_timeit)
  append_time_timeit = timeit.timeit(stmt='list(append_list.append(i) for i in init_list)',
                    setup='append_list=list();init_list=range(10)',
                    number=100000)
  print('append_time_timeit: ', append_time_timeit)

由于時(shí)間很長(zhǎng),代碼中特意將 number 從一百萬(wàn)次改成了十萬(wàn)次。運(yùn)行結(jié)果如下:

('insert_time_timeit: ', 330.46189400000003)
('append_time_timeit: ', 0.21436310000001413)

相對(duì)來(lái)說(shuō),對(duì)于相同的操作,使用函數(shù)的運(yùn)行時(shí)間遠(yuǎn)小于直接傳入代碼表達(dá)式的時(shí)間,頭部插入數(shù)據(jù)的尤其明顯。

二、使用 repeat() 函數(shù)測(cè)試運(yùn)行時(shí)間

1. repeat(stmt="pass", setup="pass", timer=default_timer, repeat=default_repeat, number=default_number) 函數(shù)介紹

repeat() 函數(shù)有五個(gè)參數(shù),每個(gè)參數(shù)都是關(guān)鍵字參數(shù),都有默認(rèn)值。相比 timeit() 函數(shù)而言,timeit() 函數(shù)有的參數(shù) repeat() 函數(shù)都有,此外,repeat() 函數(shù)多了一個(gè) repeat 參數(shù)。

repeat:表示測(cè)試要重復(fù)幾次,可以理解為將相同參數(shù)的 timeit() 函數(shù)重復(fù)執(zhí)行。最終的結(jié)果構(gòu)成一個(gè)列表返回,repeat 默認(rèn)為3次。

2. 測(cè)試函數(shù)的運(yùn)行時(shí)間

現(xiàn)在使用 repeat() 來(lái)測(cè)試上面兩個(gè)函數(shù)的運(yùn)行時(shí)間。

 insert_time_repeat = timeit.repeat(stmt='insert_time_test()',
                    setup='from __main__ import insert_time_test')
  print('insert_time_repeat: ', insert_time_repeat)
  append_time_repeat = timeit.repeat(stmt='append_time_test()',
                    setup='from __main__ import append_time_test')

  print('append_time_repeat: ', append_time_repeat)

運(yùn)行結(jié)果如下:

('insert_time_repeat: ', [2.7707739, 2.908885, 2.7164823999999994])
('append_time_repeat: ', [1.7458063, 1.777368000000001, 1.8675014999999995])

3. 測(cè)試代碼(表達(dá)式)的運(yùn)行時(shí)間

繼續(xù)使用 repeat() 測(cè)試上面代碼的運(yùn)行時(shí)間,直接傳入代碼,上面將 number 改成十萬(wàn)次后,時(shí)間還是很長(zhǎng)(300多秒),所以繼續(xù)減小 number ,改成一萬(wàn)次。

  insert_time_repeat = timeit.repeat(stmt='list(insert_list.insert(0, i) for i in init_list)',
                    setup='insert_list=list();init_list=range(10)',
                    repeat=5,
                    number=10000)
  print('insert_time_repeat: ', insert_time_repeat)
  append_time_repeat = timeit.repeat(stmt='list(append_list.append(i) for i in init_list)',
                    setup='append_list=list();init_list=range(10)',
                    repeat=5,
                    number=10000)
  print('append_time_repeat: ', append_time_repeat)

運(yùn)行結(jié)果如下:

('insert_time_repeat: ', [2.591015, 2.5814996999999997, 2.5547322, 2.6153070000000005, 2.5496864000000006])
('append_time_repeat: ', [0.0181692999999985, 0.01746889999999901, 0.018901899999999472, 0.018737400000000903, 0.018211900000000725])

三、使用 Timer 類測(cè)試運(yùn)行時(shí)間

1. Timer 類介紹

上面使用了 timeit() 函數(shù)和 repeat() 函數(shù),其實(shí)在 timeit 模塊中,這兩個(gè)函數(shù)都是對(duì) Timer 類做了進(jìn)一步的封裝,實(shí)際調(diào)用的還是 Timer 類中的方法。

在 Timer 類中,實(shí)現(xiàn)了兩個(gè)方法,timeit() 方法和 repeat() 方法,上面兩個(gè)函數(shù)調(diào)用的就是這兩個(gè)方法。

在使用  from timeit import ... 時(shí),只能導(dǎo)入 Timer 類,所以可以直接使用 Timer 類來(lái)測(cè)試,可以自己去調(diào)用方法,使用起來(lái)更靈活。

2. 測(cè)試列表頭部添加

先實(shí)例化一個(gè) Timer 類的對(duì)象,實(shí)例化時(shí)傳入 stmt 和 setup 參數(shù)(參數(shù)的含義與上面一致),timer 參數(shù)保持默認(rèn),然后通過(guò)實(shí)例對(duì)象調(diào)用對(duì)應(yīng)的 timeit() 方法或 repeat() 方法,在 timeit() 方法中傳入 number,在repeat() 方法中傳入 number 和 repeat 。

使用 timeit() 方法和 repeat() 方法測(cè)試從頭部添加數(shù)據(jù)的運(yùn)行時(shí)間。

 timer_insert = timeit.Timer(stmt='insert_time_test()', setup='from __main__ import insert_time_test')
  insert_time_timeit = timer_insert.timeit(number=1000000)
  print('insert_time_timeit: ', insert_time_timeit)
  insert_time_repeat = timer_insert.repeat(number=1000000)
  print('insert_time_repeat: ', insert_time_repeat)

運(yùn)行結(jié)果如下:

('insert_time_timeit: ', 2.7732486)
('insert_time_repeat: ', [2.7367806999999997, 2.707402600000001, 2.7288245999999994])

3. 測(cè)試列表尾部添加

使用 timeit() 方法和 repeat() 方法測(cè)試從尾部添加數(shù)據(jù)的運(yùn)行時(shí)間。

  timer_append = timeit.Timer(stmt='append_time_test()', setup='from __main__ import append_time_test')
  append_time_timeit = timer_append.timeit(number=1000000)
  print('append_time_timeit: ', append_time_timeit)
  append_time_repeat = timer_append.repeat(number=1000000)
  print('append_time_repeat: ', append_time_repeat)

運(yùn)行結(jié)果如下:

('append_time_timeit: ', 1.9966106000000001)
('append_time_repeat: ', [1.9523343999999998, 1.8373857999999998, 1.8695377000000004])

以上就是如何在Python中使用timeit模塊,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

分享文章:如何在Python中使用timeit模塊-創(chuàng)新互聯(lián)
轉(zhuǎn)載源于:http://muchs.cn/article48/hcphp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站App開發(fā)、企業(yè)網(wǎng)站制作、微信小程序企業(yè)建站、全網(wǎng)營(yíng)銷推廣

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化