Python如何統(tǒng)計函數調用的耗時
更新時間:2024年04月25日 09:26:07 作者:小鋒學長生活大爆炸
這篇文章主要為大家詳細介紹了如何使用Python實現統(tǒng)計函數調用的耗時,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
相比于timerit等裝飾器用法,我希望能不修改函數,只統(tǒng)計函數調用的用時。常規(guī)方法是在函數調用前后添加time,比如:
# 開始計時 start_time = time.perf_counter() # 調用函數 x = xxx() # 結束計時 end_time = time.perf_counter()
但如果有很多這樣的函數,每次都寫這么多實在太麻煩。
實際上我們可以通過with的方式來計時。所以,代碼如下:
import time class Timer: """ 一個計時上下文管理器,用于測量代碼塊的執(zhí)行時間。 它可以根據用戶的需求以秒或納秒為單位測量時間。 屬性: use_ns (bool): 如果為True,則計時器以納秒為單位測量時間;如果為False,則以秒為單位。 start (float|int): 測量開始的時間。 end (float|int): 測量結束的時間。 interval (float|int): 計算的開始和結束時間之間的持續(xù)時間。 """ def __init__(self, use_ns=False): """ 使用選擇是否使用納秒精度初始化 Timer。 參數: use_ns (bool): 確定是否使用納秒進行時間測量,默認為False。 """ self.use_ns = use_ns self.start = None self.end = None self.interval = None def __enter__(self): """ 啟動計時器。當進入上下文塊時記錄開始時間。 返回: Timer: 返回自身對象,以便在上下文外部訪問屬性。 """ 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): """ 結束計時器。當退出上下文塊時記錄結束時間。 此函數還計算時間間隔并打印經過的時間。 參數: exc_type: 如果在上下文中引發(fā)異常,則為異常類型。 exc_value: 如果引發(fā)異常,則為異常值。 traceback: 如果發(fā)生異常,則為回溯詳細信息。 返回: None """ if self.use_ns: self.end = time.perf_counter_ns() self.interval = self.end - self.start print(f"經過時間:{self.interval} 納秒") else: self.end = time.perf_counter() self.interval = self.end - self.start print(f"經過時間:{self.interval:.6f} 秒")
用法示例:
def test_func(): for i in range(100000): pass # 使用 Timer 類的示例 with Timer(use_ns=True) as timer_ns: test_func() print(f"記錄的時間(納秒):{timer_ns.interval}") with Timer(use_ns=False) as timer_sec: test_func() print(f"記錄的時間(秒):{timer_sec.interval:.6f}")
到此這篇關于Python如何統(tǒng)計函數調用的耗時的文章就介紹到這了,更多相關Python統(tǒng)計函數調用耗時內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Python中np.percentile和df.quantile分位數詳解
分位數(Quantile)亦稱分位點是指將一個隨機變量的概率分布范圍分為幾個等份的數值點,下面這篇文章主要給大家介紹了關于Python中np.percentile和df.quantile分位數的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-05-05Python使用Plotly繪制常見5種動態(tài)交互式圖表
Plotly是一個非常強大的開源數據可視化框架,它通過構建基于 HTML 的交互式圖表來顯示信息,可創(chuàng)建各種形式的精美圖表。本文將用Plotly庫繪制常見的五種動態(tài)交互式圖表,感興趣的可以學習一下2022-03-03利用python實現flappy bird 游戲(完整代碼)
python 中 pygame模塊能讓我們很方便的編寫游戲,16年我用python 仿制了flappy bird 游戲,下面是游戲的完整代碼以及素材,分享給大家2021-11-11Python深度學習實戰(zhàn)PyQt5窗口切換的堆疊布局示例詳解
本文以堆疊窗口控件為例,詳細介紹堆疊布局的界面設計和程序實現過程,通過案例帶小白創(chuàng)建一個典型的堆疊布局多窗口切換程序2021-10-10