這篇文章主要介紹“如何剖析Python代碼的執(zhí)行性能”,在日常操作中,相信很多人在如何剖析Python代碼的執(zhí)行性能問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”如何剖析Python代碼的執(zhí)行性能”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
創(chuàng)新互聯(lián)建站是專業(yè)的烏什網(wǎng)站建設(shè)公司,烏什接單;提供網(wǎng)站制作、成都網(wǎng)站制作,網(wǎng)頁設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行烏什網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!
剖析代碼性能可以使用Python標(biāo)準(zhǔn)庫中的cProfile
和pstats
模塊,cProfile
的run
函數(shù)可以執(zhí)行代碼并收集統(tǒng)計(jì)信息,創(chuàng)建出Stats
對象并打印簡單的剖析報(bào)告。Stats
是pstats
模塊中的類,它是一個(gè)統(tǒng)計(jì)對象。當(dāng)然,也可以使用三方工具line_profiler
和memory_profiler
來剖析每一行代碼耗費(fèi)的時(shí)間和內(nèi)存,這兩個(gè)三方工具都會(huì)用非常友好的方式輸出剖析結(jié)構(gòu)。如果使用PyCharm,可以利用“Run”菜單的“Profile”菜單項(xiàng)對代碼進(jìn)行性能分析,PyCharm中可以用表格或者調(diào)用圖(Call Graph)的方式來顯示性能剖析的結(jié)果。
下面是使用cProfile
剖析代碼性能的例子。
example.py
import cProfile def is_prime(num): for factor in range(2, int(num ** 0.5) + 1): if num % factor == 0: return False return True class PrimeIter: def __init__(self, total): self.counter = 0 self.current = 1 self.total = total def __iter__(self): return self def __next__(self): if self.counter < self.total: self.current += 1 while not is_prime(self.current): self.current += 1 self.counter += 1 return self.current raise StopIteration() cProfile.run('list(PrimeIter(10000))')
如果使用line_profiler
三方工具,可以直接剖析is_prime
函數(shù)每行代碼的性能,需要給is_prime
函數(shù)添加一個(gè)profiler
裝飾器,代碼如下所示。
@profiler def is_prime(num): for factor in range(2, int(num ** 0.5) + 1): if num % factor == 0: return False return True
安裝line_profiler
。
pip install line_profiler
使用line_profiler
。
kernprof -lv example.py
運(yùn)行結(jié)果如下所示。
Line # Hits Time Per Hit % Time Line Contents ============================================================== 1 @profile 2 def is_prime(num): 3 86624 48420.0 0.6 50.5 for factor in range(2, int(num ** 0.5) + 1): 4 85624 44000.0 0.5 45.9 if num % factor == 0: 5 6918 3080.0 0.4 3.2 return False 6 1000 430.0 0.4 0.4 return True
到此,關(guān)于“如何剖析Python代碼的執(zhí)行性能”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!
網(wǎng)頁標(biāo)題:如何剖析Python代碼的執(zhí)行性能
本文路徑:http://bm7419.com/article24/jddsce.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站導(dǎo)航、外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站策劃、企業(yè)建站、定制網(wǎng)站、軟件開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)