日韩欧乱色一区二区三区在线_久久―日本道色综合久久_欧美日本一区二区_网曝91综合精品门事件在线

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > Python 性能剖分工具

Python 性能剖分工具

來源:千鋒教育
發布人:xqq
時間: 2023-11-07 10:05:09 1699322709

眼看著項目即將完成,卻被測試人員告知沒有通過性能測試,這種情況在開發中屢見不鮮。接下來的工作就是加班加點地找出性能瓶頸,然后進行優化,再進行性能測試,如此這般周而復始直到通過性能測試。盡管豐富的工作經驗有助于性能優化,但只有科學地應用工具才能在最短的時間內找出最佳優化粒度的瓶頸代碼段,達到事半功倍的效果。

profile、cProfile與hotshot

Python內置了豐富的性能優化工具來幫助我們定位性能瓶頸,如:profile、cProfile和hotshot。它們易于使用,而且有完備的支持文檔可供參考。下面以最常用的profile模塊為例來說明它們的使用方法,假定要剖分的腳本文件為foo.py,它的內容如下:

deffoo():

sum=0

foriinrange(100):

sum+=i

returnsum

if__name__=="__main__":

foo()

對foo.py進行性能剖分的方法之一是修改foo.py里的if程序塊,引入profile模塊:

if__name__=="__main__":

importprofile

profile.run("foo()")

然后執行foo.py即可完成性能剖分,剖分結果將以文本報表的形式打印到標準輸出。

因為上述方法需要修改foo.py文件,所以我們通常更傾向于使用無需修改源文件的方法——就是在命令行中用應用python的–m參數來執行profile:

python–mprofilefoo.py

除了可以使用profile模塊外,還可以使用cProfile模塊。cProfile由C語言實現,是剖分代價更低的剖分器,有和profile模塊相同的接口,但只能用于2.5或以上版本。Python另一個內置的剖分器是hotshot,但是hotshot模塊已經不再推薦使用,因為將來它可能會被移出標準庫。

pstats

無論使用哪個剖分器,它的剖分數據都可以保存到二進制文件,如foo.prof。分析和查看剖分結果文件需要使用pstats模塊,它極具伸縮性,可以輸出形式多樣的文本報表,是文本界面下不可或缺的工具。

使用pstats分析剖分結果很簡單,幾行代碼就可以了:

importpstats

p=pstats.Stats("foo.prof")

p.sort_stats("time").print_stats()

運行上述腳本將輸出結果為按函數內部運行時間(不計調用子函數的時間)長短排序的報表。

sort_stats()方法是pstats.Stats最重要的方法之一,它用以對剖分數據進行排序。sort_stats()接受一個字符串參數,這個字符串標識了排序的字段,常用的可選的參數及其意義如下:

ncalls’

被調用次數

‘cumulative’

函數運行的總時間

‘nfl’

Name/file/line

‘time’

函數內部運行時間(不計調用子函數的時間)

除了sort_stats()外,pstats.Stats還有print_callees()和print_callers()方法用以輸出指定函數所調用的函數和調用過指定函數的函數。

除了編編程接口外,pstats還提供了友好的命令行交互環境,在命令行執行python–mpstats就可以進入交互環境,在交互環境里可以使用read/add指令讀入/加載剖分結果文件,stats指令用以查看報表,callees和callers指令用以查看特定函數的被調用者和調用者。下圖是pstats的截圖,標識了它的基本使用方法

以上內容為大家介紹了Python性能剖分工具,希望對大家有所幫助,如果想要了解更多Python相關知識,請關注IT培訓機構:千鋒教育。http://m.hangjiakeji.com/

tags: python培訓
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
主站蜘蛛池模板: 穆棱市| 常德市| 通州市| 五大连池市| 辰溪县| 扬中市| 宁阳县| 建平县| 辽源市| 丽水市| 永德县| 滁州市| 扶绥县| 新密市| 沂源县| 台北县| 深泽县| 吴桥县| 县级市| 昌吉市| 南城县| 万源市| 宁强县| 井冈山市| 日土县| 阳泉市| 泽州县| 镇原县| 扎兰屯市| 宁陵县| 镇安县| 敦化市| 八宿县| 理塘县| 玉树县| 泰宁县| 荥阳市| 嫩江县| 天峨县| 怀安县| 五莲县|