Python如何統(tǒng)計(jì)函數(shù)調(diào)用的耗時(shí)
相比于timerit等裝飾器用法,我希望能不修改函數(shù),只統(tǒng)計(jì)函數(shù)調(diào)用的用時(shí)。常規(guī)方法是在函數(shù)調(diào)用前后添加time,比如:
# 開(kāi)始計(jì)時(shí) start_time = time.perf_counter() # 調(diào)用函數(shù) x = xxx() # 結(jié)束計(jì)時(shí) end_time = time.perf_counter()
但如果有很多這樣的函數(shù),每次都寫(xiě)這么多實(shí)在太麻煩。
實(shí)際上我們可以通過(guò)with的方式來(lái)計(jì)時(shí)。所以,代碼如下:
import time class Timer: """ 一個(gè)計(jì)時(shí)上下文管理器,用于測(cè)量代碼塊的執(zhí)行時(shí)間。 它可以根據(jù)用戶的需求以秒或納秒為單位測(cè)量時(shí)間。 屬性: use_ns (bool): 如果為T(mén)rue,則計(jì)時(shí)器以納秒為單位測(cè)量時(shí)間;如果為False,則以秒為單位。 start (float|int): 測(cè)量開(kāi)始的時(shí)間。 end (float|int): 測(cè)量結(jié)束的時(shí)間。 interval (float|int): 計(jì)算的開(kāi)始和結(jié)束時(shí)間之間的持續(xù)時(shí)間。 """ def __init__(self, use_ns=False): """ 使用選擇是否使用納秒精度初始化 Timer。 參數(shù): use_ns (bool): 確定是否使用納秒進(jìn)行時(shí)間測(cè)量,默認(rèn)為False。 """ self.use_ns = use_ns self.start = None self.end = None self.interval = None def __enter__(self): """ 啟動(dòng)計(jì)時(shí)器。當(dāng)進(jìn)入上下文塊時(shí)記錄開(kāi)始時(shí)間。 返回: Timer: 返回自身對(duì)象,以便在上下文外部訪問(wèn)屬性。 """ if self.use_ns: self.start = time.perf_counter_ns() else: self.start = time.perf_counter() return self def __exit__(self, exc_type, exc_value, traceback): """ 結(jié)束計(jì)時(shí)器。當(dāng)退出上下文塊時(shí)記錄結(jié)束時(shí)間。 此函數(shù)還計(jì)算時(shí)間間隔并打印經(jīng)過(guò)的時(shí)間。 參數(shù): exc_type: 如果在上下文中引發(fā)異常,則為異常類(lèi)型。 exc_value: 如果引發(fā)異常,則為異常值。 traceback: 如果發(fā)生異常,則為回溯詳細(xì)信息。 返回: None """ if self.use_ns: self.end = time.perf_counter_ns() self.interval = self.end - self.start print(f"經(jīng)過(guò)時(shí)間:{self.interval} 納秒") else: self.end = time.perf_counter() self.interval = self.end - self.start print(f"經(jīng)過(guò)時(shí)間:{self.interval:.6f} 秒")
用法示例:
def test_func(): for i in range(100000): pass # 使用 Timer 類(lèi)的示例 with Timer(use_ns=True) as timer_ns: test_func() print(f"記錄的時(shí)間(納秒):{timer_ns.interval}") with Timer(use_ns=False) as timer_sec: test_func() print(f"記錄的時(shí)間(秒):{timer_sec.interval:.6f}")
到此這篇關(guān)于Python如何統(tǒng)計(jì)函數(shù)調(diào)用的耗時(shí)的文章就介紹到這了,更多相關(guān)Python統(tǒng)計(jì)函數(shù)調(diào)用耗時(shí)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- python統(tǒng)計(jì)函數(shù)被調(diào)用次數(shù)的實(shí)現(xiàn)
- 利用Python實(shí)現(xiàn)簡(jiǎn)單的Excel統(tǒng)計(jì)函數(shù)
- python?DataFrame數(shù)據(jù)分組統(tǒng)計(jì)groupby()函數(shù)的使用
- python統(tǒng)計(jì)函數(shù)庫(kù)scipy.stats的用法解析
- Python實(shí)現(xiàn)Mysql數(shù)據(jù)統(tǒng)計(jì)及numpy統(tǒng)計(jì)函數(shù)
- Python使用統(tǒng)計(jì)函數(shù)繪制簡(jiǎn)單圖形實(shí)例代碼
- Python中統(tǒng)計(jì)函數(shù)運(yùn)行耗時(shí)的方法
- python常見(jiàn)統(tǒng)計(jì)分析處理函數(shù)解讀
相關(guān)文章
詳細(xì)講解用Python發(fā)送SMTP郵件的教程
這篇文章主要詳細(xì)講解了用Python發(fā)送SMTP郵件的教程,包括在郵件中添加圖片等文件,強(qiáng)烈推薦!需要的朋友可以參考下2015-04-04Python中np.percentile和df.quantile分位數(shù)詳解
分位數(shù)(Quantile)亦稱(chēng)分位點(diǎn)是指將一個(gè)隨機(jī)變量的概率分布范圍分為幾個(gè)等份的數(shù)值點(diǎn),下面這篇文章主要給大家介紹了關(guān)于Python中np.percentile和df.quantile分位數(shù)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05Python使用Plotly繪制常見(jiàn)5種動(dòng)態(tài)交互式圖表
Plotly是一個(gè)非常強(qiáng)大的開(kāi)源數(shù)據(jù)可視化框架,它通過(guò)構(gòu)建基于 HTML 的交互式圖表來(lái)顯示信息,可創(chuàng)建各種形式的精美圖表。本文將用Plotly庫(kù)繪制常見(jiàn)的五種動(dòng)態(tài)交互式圖表,感興趣的可以學(xué)習(xí)一下2022-03-03django 解決擴(kuò)展自帶User表遇到的問(wèn)題
這篇文章主要介紹了django 解決擴(kuò)展自帶User表遇到的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-05-05詳解python調(diào)度框架APScheduler使用
本篇文章主要介紹了詳解python調(diào)度框架APScheduler使用,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03利用python實(shí)現(xiàn)flappy bird 游戲(完整代碼)
python 中 pygame模塊能讓我們很方便的編寫(xiě)游戲,16年我用python 仿制了flappy bird 游戲,下面是游戲的完整代碼以及素材,分享給大家2021-11-11python文件絕對(duì)路徑寫(xiě)法介紹(windows)
今天小編就為大家分享一篇python文件絕對(duì)路徑寫(xiě)法介紹(windows),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12Python深度學(xué)習(xí)實(shí)戰(zhàn)PyQt5窗口切換的堆疊布局示例詳解
本文以堆疊窗口控件為例,詳細(xì)介紹堆疊布局的界面設(shè)計(jì)和程序?qū)崿F(xiàn)過(guò)程,通過(guò)案例帶小白創(chuàng)建一個(gè)典型的堆疊布局多窗口切換程序2021-10-10