亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python中計時程序運行時間的幾種常用方法

 更新時間:2025年04月18日 10:16:39   作者:NameError_sfj  
這篇文章主要介紹了Python中計時程序運行時間的幾種常用方法,分別是一般方法、基于上下文管理器和基于裝飾器,每種方法都有其適用場景和優(yōu)缺點,文中通過代碼介紹的非常詳細,需要的朋友可以參考下

前言

在實際工作中,我們常常需要知道程序的實際運行時間(wall-clock time, real time)。本文就介紹了幾種在Python中計時程序運行耗時的方法。

1. 一般方法

最為常見的方法,就是在代碼的開頭和結(jié)尾分別獲取時間戳,然后兩者之差便是程序運行時間。

import time

def do_something(nsec=0):
	if isinstance(nsec, (int, float)):
		time.sleep(nsec)  # 模擬程序運行耗時

if __name__ == "__main__":
	start_time	= time.perf_counter()  # 記錄開始時間戳
	do_something(3)
	do_something(1)
	do_something(0.5)
	end_time = time.perf_counter()  # 記錄結(jié)束時間戳
	print(f"耗時 {end_time - start_time:.3f} s")

這是最簡單直接的方法,但問題是當需要計時的部分很多的時候,會導致大量的重復代碼。

2. 基于上下文管理器

相比之下,使用Python的上下文管理器(context manager)是更加優(yōu)雅,復用性更好的解決方案。Python的上下文管理器機制是用來更加方便地管理如文件、數(shù)據(jù)庫連接、鎖等資源的,確保在使用結(jié)束后恰當?shù)仃P閉及釋放資源,以避免造成泄露。
然而,上下文管理器的用途不僅限于資源的管理,其適合于所有的代碼開始和結(jié)束的成對操作,就比如計時程序的運行時間。

import time 

class Timer:
	"""
	按照 xxh xxm xxs格式計時程序運行時間的計時上下文管理器
	"""
	def __init__(self, code_part):
		self._part = code_part
		
	def __enter__(self):
		self._enter_time = time.perf_counter()
		
	def __exit__(self, *exc_args):  # 不做異常處理,因此將異常相關的參數(shù)打包
		time_span = time.perf_counter() - self._enter_time
		hours, seconds = divmod(time_span, 3600)
		minutes, seconds = divmod(seconds, 60) 
		print(f"{self._part}耗時 {int(hours)}h {int(minutes)}m {seconds:.2f}s")

def do_something(nsec=0):
	if isinstance(nsec, (int, float)):
		time.sleep(nsec)  # 模擬程序運行耗時

if __name__ == "__main__":
	with Timer("Main"):
		with Timer("Part1"):
			do_something(0.3)
		with Timer("Part2"), open("demo_file.txt", "wt") as f:
			f.write("Hello, World\n")
			do_something(2)
		do_something(1)

3. 基于裝飾器

使用Python的裝飾器特性,可以十分方便地在函數(shù)水平添加計時器,計時單個函數(shù)的運行時間。

import time
from functools import wraps

def timer(func):
	@wraps(func)
	def inner(*args, **kwargs):
		start_time = time.perf_counter()
		retval = func(*args, **kwargs)
		time_span = time.perf_counter() - start_time
		hours, seconds = divmod(time_span, 3600)
		minutes, seconds = divmod(seconds, 60) 
		print(f"{func.__name__}耗時 {int(hours)}h {int(minutes)}m {seconds:.2f}s")
		return retval
	return inner

@timer
def do_something(nsec=0):
	if isinstance(nsec, (int, float)):
		time.sleep(nsec)  # 模擬程序運行耗時

@timer
def main():
	do_something(1)
	time.sleep(0.5)

if __name__ == "__main__":
	main()	

總結(jié) 

到此這篇關于Python中計時程序運行時間的幾種常用方法的文章就介紹到這了,更多相關Python計時程序運行時間方法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 如何利用itertuples對DataFrame進行遍歷

    如何利用itertuples對DataFrame進行遍歷

    這篇文章主要介紹了如何利用itertuples對DataFrame進行遍歷問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • PyCharm運行Python代碼時出現(xiàn)"未找到模塊"錯誤解決步驟

    PyCharm運行Python代碼時出現(xiàn)"未找到模塊"錯誤解決步驟

    在使用python的過程中經(jīng)常會遇到一個問題,就是叫什么名字的模塊未發(fā)現(xiàn),下面這篇文章主要給大家介紹了關于PyCharm運行Python代碼時出現(xiàn)"未找到模塊"錯誤的解決步驟,需要的朋友可以參考下
    2023-11-11
  • python pip安裝的包放在哪個目錄(site-packages目錄的位置)

    python pip安裝的包放在哪個目錄(site-packages目錄的位置)

    這篇文章主要介紹了python pip安裝的包放在哪個目錄(site-packages目錄的位置),通常安裝在python安裝目錄下的lib/site-packages目錄下,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-06-06
  • python筆記:mysql、redis操作方法

    python筆記:mysql、redis操作方法

    下面小編就為大家?guī)硪黄猵ython筆記:mysql、redis操作方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • 關于Python調(diào)用百度語音合成SDK實現(xiàn)文字轉(zhuǎn)音頻的方法

    關于Python調(diào)用百度語音合成SDK實現(xiàn)文字轉(zhuǎn)音頻的方法

    這篇文章主要介紹了關于Python調(diào)用百度語音合成SDK實現(xiàn)文字轉(zhuǎn)音頻的方法,AipSpeech是語音合成的Python?SDK客戶端,為使用語音合成的開發(fā)人員提供了一系列的交互方法,需要的朋友可以參考下
    2023-07-07
  • python requests證書問題解決

    python requests證書問題解決

    這篇文章主要介紹了python requests證書問題解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-09-09
  • Python學習Turtle庫畫對稱勾股樹體會分形驚艷

    Python學習Turtle庫畫對稱勾股樹體會分形驚艷

    這篇文章主要為大家介紹了Python學習中如何使用Turtle庫畫對稱勾股樹,從而體會到分形世界的驚艷,文中附含詳細示例代碼有需要的朋友可以借鑒參考下
    2021-09-09
  • django為Form生成的label標簽添加class方式

    django為Form生成的label標簽添加class方式

    這篇文章主要介紹了django為Form生成的label標簽添加class方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • Python 多線程超詳細到位總結(jié)

    Python 多線程超詳細到位總結(jié)

    線程在程序中是獨立的、并發(fā)的執(zhí)行流。與分隔的進程相比,進程中線程之間的隔離程度要小,它們共享內(nèi)存、文件句柄和其他進程應有的狀態(tài)。線程的劃分尺度小于進程,使多線程程序的并發(fā)性高。進程在執(zhí)行過程中擁有獨立內(nèi)存單元,而多個線程共享內(nèi)存,從而提升程序運行效率
    2021-11-11
  • anaconda的安裝和配置環(huán)境及導入pycharm的方法

    anaconda的安裝和配置環(huán)境及導入pycharm的方法

    這篇文章主要介紹了anaconda的安裝和配置環(huán)境及導入pycharm的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03

最新評論