真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

python四個(gè)性能檢測(cè)工具,包括函數(shù)的運(yùn)行內(nèi)存、時(shí)間等等...

python雖然是一門'慢語(yǔ)言',但是也有著比較多的性能檢測(cè)工具來(lái)幫助我們優(yōu)化程序的運(yùn)行效率。

10年積累的成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問(wèn)題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站策劃后付款的網(wǎng)站建設(shè)流程,更有金牛免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。

【閱讀全文】

這里總結(jié)了五個(gè)比較好的python性能檢測(cè)工具,包括內(nèi)存使用、運(yùn)行時(shí)間、執(zhí)行次數(shù)等方面。

首先,來(lái)編寫一個(gè)基礎(chǔ)的python函數(shù)用于在后面的各種性能測(cè)試。

def base_func():
    for n in range():
        print('當(dāng)前n的值是:{}'.format(n))

1、memory_profiler進(jìn)程監(jiān)視

memory_profiler是python的非標(biāo)準(zhǔn)庫(kù),所以這里采用pip的方式進(jìn)行安裝。
它能夠監(jiān)視進(jìn)程、了解內(nèi)存使用等情況。

pip install memory_profiler

安裝好memory_profiler庫(kù)以后,直接使用注解的方式進(jìn)行測(cè)試

from memory_profiler import profile

@profile
def base_func1():
    for n in range():
        print('當(dāng)前n的值是:{}'.format(n))


base_func1()

# Line #    Mem usage    Increment  Occurrences   Line Contents
# =============================================================
#     28     45.3 MiB     45.3 MiB           1   @profile
#     29                                         def base_func():
#     30     45.3 MiB      0.0 MiB              for n in range():
#     31     45.3 MiB      0.0 MiB                  print('當(dāng)前n的值是:{}'.format(n))

從返回的數(shù)據(jù)結(jié)果來(lái)看,執(zhí)行當(dāng)前函數(shù)使用了45.3 MiB的內(nèi)存。

2、timeit 時(shí)間使用情況

timeit是python的內(nèi)置模塊,可以測(cè)試單元格的代碼運(yùn)行時(shí)間,由于是內(nèi)置模塊所以并不需要單獨(dú)安裝。

import timeit

def base_func2():
    for n in range():
        print('當(dāng)前n的值是:{}'.format(n))

res = timeit.timeit(base_func2,number=5)

print('當(dāng)前的函數(shù)的運(yùn)行時(shí)間是:{}'.format(res))

當(dāng)前的函數(shù)的運(yùn)行時(shí)間是:0.

根據(jù)上面函數(shù)的運(yùn)行返回結(jié)果,函數(shù)的運(yùn)行時(shí)間是0.96秒。

3、line_profiler行代碼運(yùn)行時(shí)間檢測(cè)

如果在只需要檢測(cè)函數(shù)的局部運(yùn)行時(shí)間的話就可以使用line_profiler了,它可以檢測(cè)出每行代碼的運(yùn)行時(shí)間。
line_profiler是python的非標(biāo)準(zhǔn)庫(kù),使用的使用pip的方式安裝一下。

pip install line_profiler

最簡(jiǎn)便的使用方式直接將需要測(cè)試的函數(shù)加入即可。

def base_func3():
    for n in range():
        print('當(dāng)前n的值是:{}'.format(n))

from line_profiler import LineProfiler

lp = LineProfiler()

lp_wrap = lp(base_func3)

lp_wrap()

lp.print_stats()

# Line #      Hits         Time  Per Hit   % Time  Line Contents
# ==============================================================
#     72                                           def base_func3():
#     73          .0     16.3      4.8      for n in range():
#     74         .0    320.8     95.2          print('當(dāng)前n的值是:{}'.format(n))

從運(yùn)行結(jié)果可以看出每行代碼的運(yùn)行時(shí)間及比例,注意這里的時(shí)間單位是微妙。

4、heartrate可視化檢測(cè)工具

heartrate最值得推薦的是可以在網(wǎng)頁(yè)上面向檢測(cè)心率一樣檢測(cè)程序的執(zhí)行過(guò)程,同時(shí),
他還是非標(biāo)準(zhǔn)庫(kù),使用pip的方式進(jìn)行安裝。

# pip install heartrate

import heartrate

heartrate.trace(browser=True)

def base_func4():
    for n in range():
        print('當(dāng)前n的值是:{}'.format(n))

運(yùn)行以后,控制臺(tái)打印如下日志:

#  * Serving Flask app "heartrate.core" (lazy loading)
#  * Environment: production
#    WARNING: This is a development server. Do not use it in a production deployment.
#    Use a production WSGI server instead.
#  * Debug mode: off

并且自動(dòng)打開瀏覽器地址:http://127.0.0.1:9999

【往期精彩】

python-turtle繪制雪容融,已打包成exe可直接運(yùn)行(附源碼)

如何將多張圖片合成mp4視頻格式,并加入背景音樂(lè)...

模型已經(jīng)寫好了,怎么表白就看你的了!

python如何實(shí)現(xiàn)網(wǎng)絡(luò)測(cè)試,了解一下speedtest-cli...

又是櫻花盛開的季節(jié),使用小烏龜來(lái)畫一顆櫻花樹吧!


新聞名稱:python四個(gè)性能檢測(cè)工具,包括函數(shù)的運(yùn)行內(nèi)存、時(shí)間等等...
本文路徑:http://weahome.cn/article/dsogpsj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部