欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python使用timeit時間模塊

 更新時間:2021年04月06日 17:06:33   作者:JSon liu  
這篇文章主要介紹了python之timeit統(tǒng)計運行時間模塊,這個技巧非常的實用,感興趣的小伙伴可以試試

1. timeit.timeit(stmt=‘pass', setup=‘pass', timer=<default timer>, number=default_number)

  • timeit() 函數(shù)有四個參數(shù),每個參數(shù)都是關鍵字參數(shù),都有默認值。
  • stmt:傳入需要測試時間的代碼,可以直接傳入代碼表達式或單個變量,也可以傳入函數(shù)。傳入函數(shù)時要在函數(shù)名后面加上小括號,讓函數(shù)執(zhí)行,如 stmt = ‘func()' 。
  • setup:傳入 stmt 的運行環(huán)境,如 stmt 中使用到的參數(shù)、變量,要導入的模塊等,如 setup = 'from __main__ import func'??梢詫懸恍姓Z句,也可以寫多行語句,寫多行語句時用分號隔開。
  • 如果 stmt 和參數(shù) setup 參數(shù)不傳值,那么就失去了測試的意義,所以這兩個參數(shù)是必要的。
  • timer: timer參數(shù)是當前操作系統(tǒng)的基本時間單位,默認會根據(jù)當前運行環(huán)境的操作系統(tǒng)自動獲取(源碼中已經(jīng)定義),保持默認即可。
  • number:要測試的代碼的運行次數(shù),默認1000000(一百萬)次,對于耗時的代碼,運行太多次會花很多時間,可以自己修改運行次數(shù)。

2. timeit.repeat(stmt="pass", setup="pass", timer=default_timer, repeat=default_repeat, number=default_number)

  • repeat()函數(shù)有五個參數(shù),每個參數(shù)都是關鍵字參數(shù),都有默認值。參數(shù)含義與timer()相同
  • repeat:表示測試要重復幾次,可以理解為將相同參數(shù)的 timeit() 函數(shù)重復執(zhí)行。最終的結果構成一個列表返回,repeat 默認為3次。

3. class timeit.Timer(stmt=‘pass', setup=‘pass', timer=<timer function>)

  • 計算小段代碼執(zhí)行速度的類,構造函數(shù)需要的參數(shù)有stmt,setup,timer。
  • 前兩個參數(shù)的默認值都是pass,timer默認會根據(jù)當前運行環(huán)境的操作系統(tǒng)自動獲取;前兩個參數(shù)都可以包含多個語句,多個語句間使用分號;或新行隔開
import timeit
def t1():
 li = [i for i in range(100000)]
def t2():
 li = []
 for i in range(100000):
  li += [i]
def t3():
 li = []
 for i in range(100000):
  li.append(i)
def t4():
 li = []
 list(range(100000))
def t5():
 li = []
 for i in range(100000):
  li.extend([i])
def t6():
 li = []
 for i in range(100000):
  li.insert(0,i)

# 方式1:timeit.timeit()
# list_t1 = timeit.timeit('t1()','from __main__ import t1',number=1)
# print("i for i in range(100000): %s" %(list_t1))

# 方式2:timeit.repeat()
# list_t2 = timeit.repeat('t2()','from __main__ import t2',repeat=1,number=1)
# print("li += i: %s" %(str(list_t2)))

# 方式3:timeit.Timer
# timer3 = timeit.Timer('t3()','from __main__ import t3')
# print("li.append(i): %s" %(timer3.timeit(number=1)))

# 直接傳入字符串對象
# list_l4 = timeit.timeit('li = [i for i in range(1000)]',number=1)
# print(str(list_l4))

# 傳入多個函數(shù)對象(;或空行分隔)
list_l5 = timeit.repeat('t4();t5();t6()','from __main__ import t4;from __main__ import t5;from __main__ import t6',repeat=1,number=1)
print(str(list_l5))

以上就是python使用timeit統(tǒng)計運行時間模塊的詳細內容,更多關于python使用timeit的資料請關注腳本之家其它相關文章!

相關文章

  • Python實現(xiàn)遍歷目錄的兩張方法總結

    Python實現(xiàn)遍歷目錄的兩張方法總結

    我們有時想直接查看文件夾里的所有文件,但使用正常的方法太麻煩了,于是本文開發(fā)出了兩個python程序,可以遍歷目錄,有需要的小伙伴可以參考下
    2024-02-02
  • python里 super類的工作原理詳解

    python里 super類的工作原理詳解

    這篇文章主要介紹了python里 super類的工作原理詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-06-06
  • python list count統(tǒng)計個數(shù)的實現(xiàn)

    python list count統(tǒng)計個數(shù)的實現(xiàn)

    這篇文章主要介紹了python list count統(tǒng)計個數(shù)的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • Linux系統(tǒng)下升級pip的完整步驟

    Linux系統(tǒng)下升級pip的完整步驟

    這篇文章主要給大家介紹了關于Linux系統(tǒng)下升級pip的完整步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • python數(shù)據(jù)類型_字符串常用操作(詳解)

    python數(shù)據(jù)類型_字符串常用操作(詳解)

    下面小編就為大家?guī)硪黄猵ython數(shù)據(jù)類型_字符串常用操作(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • 淺析Python中作用域的應用

    淺析Python中作用域的應用

    這篇文章主要是想和大家一起來討論下去Python中的命名空間、作用域和LEGB規(guī)則等不同概念,文中的示例代碼簡潔易懂,快跟隨小編一起來學習一下吧
    2023-08-08
  • python實現(xiàn)最長公共子序列

    python實現(xiàn)最長公共子序列

    這篇文章主要為大家詳細介紹了python實現(xiàn)最長公共子序列的相關代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • Python中拆分字符串的操作方法

    Python中拆分字符串的操作方法

    這篇文章主要介紹了Python中拆分字符串的操作方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-07-07
  • Python對圖像進行灰度處理的代碼介紹

    Python對圖像進行灰度處理的代碼介紹

    這篇文章主要給大家介紹了關于Python對圖像進行灰度處理的相關資料,圖像灰度化是將一幅彩色圖像轉換為灰度化圖像的過程,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-11-11
  • pandas讀取Excel批量轉換時間戳的實踐

    pandas讀取Excel批量轉換時間戳的實踐

    本文主要介紹了pandas讀取Excel批量轉換時間戳的實踐,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-02-02

最新評論