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

Python如何統(tǒng)計函數(shù)調(diào)用的耗時

 更新時間:2024年04月25日 09:26:07   作者:小鋒學(xué)長生活大爆炸  
這篇文章主要為大家詳細(xì)介紹了如何使用Python實現(xiàn)統(tǒng)計函數(shù)調(diào)用的耗時,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下

 相比于timerit等裝飾器用法,我希望能不修改函數(shù),只統(tǒng)計函數(shù)調(diào)用的用時。常規(guī)方法是在函數(shù)調(diào)用前后添加time,比如:

# 開始計時
start_time = time.perf_counter()
 
# 調(diào)用函數(shù)
x = xxx()
 
# 結(jié)束計時
end_time = time.perf_counter()

但如果有很多這樣的函數(shù),每次都寫這么多實在太麻煩。

實際上我們可以通過with的方式來計時。所以,代碼如下:

import time
 
class Timer:
    """
    一個計時上下文管理器,用于測量代碼塊的執(zhí)行時間。
    它可以根據(jù)用戶的需求以秒或納秒為單位測量時間。
    
    屬性:
        use_ns (bool): 如果為True,則計時器以納秒為單位測量時間;如果為False,則以秒為單位。
        start (float|int): 測量開始的時間。
        end (float|int): 測量結(jié)束的時間。
        interval (float|int): 計算的開始和結(jié)束時間之間的持續(xù)時間。
    """
 
    def __init__(self, use_ns=False):
        """
        使用選擇是否使用納秒精度初始化 Timer。
        參數(shù):
            use_ns (bool): 確定是否使用納秒進(jìn)行時間測量,默認(rèn)為False。
        """
        self.use_ns = use_ns
        self.start = None
        self.end = None
        self.interval = None
 
    def __enter__(self):
        """
        啟動計時器。當(dāng)進(jìn)入上下文塊時記錄開始時間。
        返回:
            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):
        """
        結(jié)束計時器。當(dāng)退出上下文塊時記錄結(jié)束時間。
        此函數(shù)還計算時間間隔并打印經(jīng)過的時間。
        參數(shù):
            exc_type: 如果在上下文中引發(fā)異常,則為異常類型。
            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)過時間:{self.interval} 納秒")
        else:
            self.end = time.perf_counter()
            self.interval = self.end - self.start
            print(f"經(jīng)過時間:{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}")

到此這篇關(guān)于Python如何統(tǒng)計函數(shù)調(diào)用的耗時的文章就介紹到這了,更多相關(guān)Python統(tǒng)計函數(shù)調(diào)用耗時內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳細(xì)講解用Python發(fā)送SMTP郵件的教程

    詳細(xì)講解用Python發(fā)送SMTP郵件的教程

    這篇文章主要詳細(xì)講解了用Python發(fā)送SMTP郵件的教程,包括在郵件中添加圖片等文件,強(qiáng)烈推薦!需要的朋友可以參考下
    2015-04-04
  • Python中np.percentile和df.quantile分位數(shù)詳解

    Python中np.percentile和df.quantile分位數(shù)詳解

    分位數(shù)(Quantile)亦稱分位點是指將一個隨機(jī)變量的概率分布范圍分為幾個等份的數(shù)值點,下面這篇文章主要給大家介紹了關(guān)于Python中np.percentile和df.quantile分位數(shù)的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • Python使用Plotly繪制常見5種動態(tài)交互式圖表

    Python使用Plotly繪制常見5種動態(tài)交互式圖表

    Plotly是一個非常強(qiáng)大的開源數(shù)據(jù)可視化框架,它通過構(gòu)建基于 HTML 的交互式圖表來顯示信息,可創(chuàng)建各種形式的精美圖表。本文將用Plotly庫繪制常見的五種動態(tài)交互式圖表,感興趣的可以學(xué)習(xí)一下
    2022-03-03
  • django 解決擴(kuò)展自帶User表遇到的問題

    django 解決擴(kuò)展自帶User表遇到的問題

    這篇文章主要介紹了django 解決擴(kuò)展自帶User表遇到的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • 詳解python調(diào)度框架APScheduler使用

    詳解python調(diào)度框架APScheduler使用

    本篇文章主要介紹了詳解python調(diào)度框架APScheduler使用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • 利用python實現(xiàn)flappy bird 游戲(完整代碼)

    利用python實現(xiàn)flappy bird 游戲(完整代碼)

    python 中 pygame模塊能讓我們很方便的編寫游戲,16年我用python 仿制了flappy bird 游戲,下面是游戲的完整代碼以及素材,分享給大家
    2021-11-11
  • python文件絕對路徑寫法介紹(windows)

    python文件絕對路徑寫法介紹(windows)

    今天小編就為大家分享一篇python文件絕對路徑寫法介紹(windows),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • Python深度學(xué)習(xí)實戰(zhàn)PyQt5窗口切換的堆疊布局示例詳解

    Python深度學(xué)習(xí)實戰(zhàn)PyQt5窗口切換的堆疊布局示例詳解

    本文以堆疊窗口控件為例,詳細(xì)介紹堆疊布局的界面設(shè)計和程序?qū)崿F(xiàn)過程,通過案例帶小白創(chuàng)建一個典型的堆疊布局多窗口切換程序
    2021-10-10
  • python爬取足球直播吧五大聯(lián)賽積分榜

    python爬取足球直播吧五大聯(lián)賽積分榜

    這篇文章主要為大家詳細(xì)介紹了python爬取足球直播吧五大聯(lián)賽積分榜,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-06-06
  • 保留已有python安裝Anaconda的方法推薦

    保留已有python安裝Anaconda的方法推薦

    在安裝Anaconda之前,有的已經(jīng)安裝過一個Python版本了,但是又不想刪除這個Python版本,該怎么辦呢??這篇文章主要給大家介紹了關(guān)于保留已有python安裝Anaconda的幾種法推薦,需要的朋友可以參考下
    2023-12-12

最新評論