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

如何使用Python標準庫進行性能測試

 更新時間:2019年06月25日 09:53:48   作者:煙火君  
這篇文章主要為大家詳細介紹了如何使用Python標準庫進行性能測試,具有一定的參考價值,感興趣的小伙伴們可以參考一下

Profile 和 cProfile

在 Python 標準庫里面有兩個模塊可以用來做性能測試。

1. 一個是 Profile,它是一個純 Python 的實現(xiàn),所以會慢一些,如果你需要對模塊進行拓展,那么這個模塊比較合適。

2. 第二個是 cProfile,從名字就可以看出這是一個 C 語言的實現(xiàn)版,官方推薦在大多數(shù)情況下使用。
這兩者的接口和數(shù)據(jù)的輸出格式是完全一樣的,你可以在這兩者之間自由的切換,所以下面我們僅以 cProfile 為例進行介紹。

使用 cProfile 進行性能測試

在 cProfile 中,進行性能測試十分簡單,只需調(diào)用 run 方法,并將需要測試的函數(shù)及參數(shù)傳遞給它即可,下面我們對fib(n) 進行性能測試。

import cProfile

def fib(n):
 if n == 0:
 return 0
 if n == 1:
 return 1
 return fib(n-1) + fib(n-2)

if __name__ == '__main__':
 cProfile.run('fib(30)')

性能測試的結(jié)果如下圖

可以看到一共進行了 2692539 次函數(shù)調(diào)用,共耗時 0.815 秒。下面每一行對應于一個函數(shù)的調(diào)用情況,其中:

1. ncalls, 函數(shù)總共調(diào)用次數(shù);
2. tottime, 這個函數(shù)調(diào)用總共花費時間;
3. percall, 每個調(diào)用的平均花費時間;
4. cumtime, 總共累計花費時間;
5. percall, 每個調(diào)用的平均累計時間;
6. filename:lineno(function), 對應函數(shù)信息。

所以從圖中可以明顯看到幾乎的耗時都在fib上,而且函數(shù)調(diào)用數(shù)過多,這主要是因為函數(shù)是遞歸調(diào)用的,并且會產(chǎn)生很多冗余分支,所以程序需要進行優(yōu)化。有兩種方法進行改進,一是緩存fib(n)的信息,不需要每次都進行計算;二是將程序改為迭代式。

而對函數(shù)值進行緩存在 Python 3 里有一個簡單的裝飾器叫做lru_cache,可以自動的幫你緩存函數(shù)的值,而不需要自己手動存儲。

import functools

@functools.lru_cache(maxsize=None)
def fib(n):
 if n == 0:
 return 0
 if n == 1:
 return 1
 return fib(n-1) + fib(n-2)

運行結(jié)果如下:

可以看到,fib 函數(shù)只調(diào)用了 31 次,幾乎所有額外的調(diào)用都命中了緩存,遠遠小于前面的調(diào)用次數(shù),運行時間也得到了相當明顯的提升。同時使用下面的迭代版程序也運行得非常快,這里就不再展開。

def fib(n):
 prev, cur = 0, 1
 if n == 0:
 return prev
 if n == 1:
 return cur
 count = 1
 while count < n:
 count += 1
 prev, cur = cur, prev + cur
 return cur

除了前面提到的 run 方法外,還有一個叫做 runctx 的方法,允許提供一些上下文參數(shù)。例如前面的 cProfile.run('fib(30)') 可以改為cProfile.runctx('fib', globals(), {'n':30})最后的運行結(jié)果是相同的。

最后,除了直接打印到命令行的方式,run 和 runctx 可以通過第二個參數(shù)傳遞文件名的方式將輸出結(jié)果寫入文件。

使用 pstats 對顯示進行控制

cProfile 雖然可以對程序進行簡單的性能測試,但是當程序過大,調(diào)用函數(shù)很多的時候,就需要一些對測試結(jié)果進行過濾和排序的工具了,而 pstats 就是這樣的一個工具。

# fib_profile.py
import cProfile
import pstats

for i in range(5):
 cProfile.run('fib(1000)', 'fib_profile_{}'.format(i))

stats = pstats.Stats('fib_profile_0')
for i in range(1, 5):
 stats.add('fib_profile_{}'.format(i))
stats.strip_dirs()
stats.sort_stats('cumulative')
stats.print_stats('fib')

上面的程序首先寫入了多個測試結(jié)果,然后初始化了 stats,可以通過 stats 的 add 方法添加新的文件,pstats 會自動的將結(jié)果聚合起來;然后 strip_dirs 將會移除文件名前面的路徑,只保留文件名;sort_stats 是對輸出結(jié)果進行排序,也就是在前面所說的那幾行里進行選擇(具體的可參閱官方文檔);最后的 print_stats 對結(jié)果進行輸出,在這面可以對行進行過濾,比如上面的程序就只輸出了包含 fib 的行;實際輸出結(jié)果如下。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • python opencv捕獲攝像頭并顯示內(nèi)容的實現(xiàn)

    python opencv捕獲攝像頭并顯示內(nèi)容的實現(xiàn)

    這篇文章主要介紹了python opencv捕獲攝像頭并顯示內(nèi)容的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-07-07
  • 基于python實現(xiàn)新春煙花盛宴效果

    基于python實現(xiàn)新春煙花盛宴效果

    這篇文章給大家用Python綻放了一場新春煙花盛宴,這里提前祝大家新春快樂呀,文中通過代碼示例給大家介紹的非常詳細,感興趣的小伙伴可以自己動手嘗試一下
    2024-02-02
  • python列表的特點分析

    python列表的特點分析

    在本篇文章里小編個大家整理的是一篇關于python列表的特點分析內(nèi)容總結(jié),有需要的朋友們可以學習下。
    2021-08-08
  • 使用11行Python代碼盜取了室友的U盤內(nèi)容

    使用11行Python代碼盜取了室友的U盤內(nèi)容

    這篇文章主要介紹了使用11行Python代碼盜取了室友的U盤內(nèi)容的相關資料,需要的朋友可以參考下
    2018-10-10
  • Django高級編程之自定義Field實現(xiàn)多語言

    Django高級編程之自定義Field實現(xiàn)多語言

    這篇文章主要介紹了Django高級編程之自定義Field實現(xiàn)多語言,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-07-07
  • python切割圖片的實現(xiàn)示例

    python切割圖片的實現(xiàn)示例

    本文主要介紹了python切割圖片的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-05-05
  • python2.7使用scapy發(fā)送syn實例

    python2.7使用scapy發(fā)送syn實例

    這篇文章主要介紹了python2.7使用scapy發(fā)送syn實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • python中split(),?os.path.split()和os.path.splitext()的用法

    python中split(),?os.path.split()和os.path.splitext()的用法

    本文主要介紹了python中split(),?os.path.split()和os.path.splitext()的用法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-02-02
  • Python如何遍歷numpy數(shù)組

    Python如何遍歷numpy數(shù)組

    這篇文章主要介紹了Python如何遍歷numpy數(shù)組問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • python 文本單詞提取和詞頻統(tǒng)計的實例

    python 文本單詞提取和詞頻統(tǒng)計的實例

    今天小編就為大家分享一篇python 文本單詞提取和詞頻統(tǒng)計的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12

最新評論