成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Python性能分析,使用cProfile可視化并解決性能瓶頸問題

開發(fā) 前端
Python標(biāo)準(zhǔn)庫已經(jīng)提供了性能分析所需的工具,即cProfile。本文將向你展示如何使用cProfile,以可視化的方式快速識別代碼中哪些部分計(jì)算開銷最高,并且應(yīng)該優(yōu)先進(jìn)行優(yōu)化。

帕累托法則無處不在,它說:

“在大多數(shù)情況下,80%的結(jié)果來自于20%的原因?!?/p>

作為一名程序員,當(dāng)代碼運(yùn)行速度不盡如人意時(shí),就需要花費(fèi)大量時(shí)間對代碼進(jìn)行相應(yīng)的重構(gòu)。但在許多情況下,所得到的速度提升并不值得花費(fèi)的精力。

Python標(biāo)準(zhǔn)庫已經(jīng)提供了性能分析所需的工具,即cProfile。本文將向你展示如何使用cProfile,以可視化的方式快速識別代碼中哪些部分計(jì)算開銷最高,并且應(yīng)該優(yōu)先進(jìn)行優(yōu)化。

安裝

cProfile

cProfile是我們將用來測量代碼的各個(gè)部分所需時(shí)間的工具,它是Python標(biāo)準(zhǔn)庫的一部分,因此無需安裝。

QCachegrind

QCachegrind將負(fù)責(zé)可視化cProfile的輸出結(jié)果,將能夠快速觀察到性能瓶頸所在。

MacOS 用戶

請檢查你是否已經(jīng)安裝了Homebrew。如果沒有安裝,請使用以下命令進(jìn)行安裝:

ruby -e “$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" < /dev/null 2> /dev/null

然后你可以安裝QCachegrind

brew install qcachegrind

其他用戶

對于其他操作系統(tǒng)的用戶,推薦Pyprof2calltree工具。

Pyprof2calltree

Pyprof2calltree將使用cProfile收集的分析數(shù)據(jù)轉(zhuǎn)換為QCachegrind可以讀取的格式。

安裝方法如下:

pip install pyprof2calltree

方法

完成安裝后,進(jìn)入包含Python腳本的文件夾。

圖片

包含要優(yōu)化的腳本的文件夾

測量

我們使用cProfile來測量腳本不同部分的運(yùn)行時(shí)間,并將結(jié)果保存在一個(gè)名為medium_example.profile的文件中(可以選擇使用任何名稱,只要它是.profile文件):

python -m cProfile -o medium_example.profile 1_generate_ML_data.py

正如你所看到的,medium_example.profile文件已添加到文件夾中:

圖片

該文件包含了運(yùn)行腳本中所涉及的不同函數(shù)的運(yùn)行時(shí)間。

可視化

現(xiàn)在,我們可以將cProfile的測量結(jié)果可視化:

pyprof2calltree -k -i medium_example.profile

圖片

QCachegrind的用戶界面包含了與所有相關(guān)函數(shù)的執(zhí)行時(shí)間有關(guān)的信息:紅色的是“Flat Profile”(左側(cè)),藍(lán)色的是“Callers”(右上方),綠色的是“Callees”(右下方)。

這個(gè)用戶界面展示的內(nèi)容較多。接下來本文會(huì)逐一解釋所有這些內(nèi)容的含義。

  • “Flat Profile” 面板出現(xiàn)在左側(cè),按時(shí)間消耗的降序排列提供了完整的函數(shù)調(diào)用列表?!癐ncl.” 列顯示每個(gè)函數(shù)消耗的總時(shí)間,考慮到其被調(diào)用者花費(fèi)的時(shí)間。
  • “Self” 列顯示僅在函數(shù)本身內(nèi)部花費(fèi)的時(shí)間,不包括其被調(diào)用者花費(fèi)的時(shí)間。
  • “Called” 列顯示函數(shù)被調(diào)用的次數(shù),而“Function” 列則顯示函數(shù)的名稱,包括其命名空間。
  • “Callers” 面板(右上方)顯示調(diào)用所選函數(shù)的函數(shù)列表,以及在每個(gè)調(diào)用者函數(shù)中花費(fèi)的時(shí)間。
  • 另一方面,“Callees” 面板(右下方)顯示由所選函數(shù)調(diào)用的函數(shù)列表,以及每個(gè)被調(diào)用者函數(shù)中花費(fèi)的時(shí)間。通過優(yōu)化這些被調(diào)用者函數(shù),你可以提高所選函數(shù)的性能。

現(xiàn)在你知道如何解讀用戶界面,接下來展示如何使用它來找到性能瓶頸。

利用QCachegrind用戶界面識別性能瓶頸

在“Flat Profile”面板的搜索欄中,輸入builtins.exec,然后選擇函數(shù)<Built-in method builtins.exec>。

在“Callees”面板中,選擇應(yīng)該占用所有(~100%)的執(zhí)行時(shí)間的第一個(gè)函數(shù)。它是你之前執(zhí)行的腳本的入口點(diǎn)。

然后,該函數(shù)會(huì)被移到“Callers”面板上,并刷新“Callees”面板顯示其中調(diào)用的函數(shù)。

在本示例中,96.52%的執(zhí)行時(shí)間來自函數(shù)generate_all_season_games_features。

如果想再深入一級,可以選擇該函數(shù)。它再次被移到“Callers”面板上,而“Callees”面板則顯示了被調(diào)用的函數(shù)。

看起來,42.73%的執(zhí)行時(shí)間來自于generate_results_hometeam_current_season,而42.57%的執(zhí)行時(shí)間來自于generate_resukts_awayteam_current_season。

由于它們對速度的影響相同,我可以選擇處理其中的任意一個(gè)函數(shù)。

或者,如果需要的話,可以更深入地調(diào)查一級。

優(yōu)化

建議從優(yōu)化耗時(shí)最長的函數(shù)開始。所需的重構(gòu)對代碼來說將是非常具體的。以下是一些典型優(yōu)化的示例:

  • 將嵌套的for循環(huán)轉(zhuǎn)換為單個(gè)for循環(huán)。
  • 實(shí)現(xiàn)多進(jìn)程。
  • 使用向量化。

重復(fù)進(jìn)行

當(dāng)應(yīng)用了第一個(gè)優(yōu)化后,可以根據(jù)實(shí)際需要多次進(jìn)行測量-可視化-優(yōu)化周期,以達(dá)到符合要求的總運(yùn)行時(shí)間。

結(jié)論

當(dāng)涉及到優(yōu)化代碼時(shí),遵循數(shù)據(jù)驅(qū)動(dòng)的方法,能確保在不進(jìn)行太多猜測和浪費(fèi)時(shí)間的情況下,取得快速進(jìn)展。

責(zé)任編輯:武曉燕 來源: Python學(xué)研大本營
相關(guān)推薦

2024-02-02 15:21:08

工具頁面性能

2019-10-31 11:50:19

MySQL數(shù)據(jù)庫Windows

2020-05-14 10:19:23

Python可視化分析

2017-02-15 09:40:38

JavaScript分析解決

2024-11-25 07:00:00

2020-09-09 10:00:41

JavaScript前端瓶頸

2017-11-27 11:59:40

Node.JSChrome調(diào)試程序

2022-04-29 15:24:53

Redis存儲慢查詢

2021-10-11 08:04:22

Python數(shù)據(jù)行程

2010-07-21 09:33:09

VMware View

2022-10-08 12:13:36

HPC

2022-08-26 09:15:58

Python可視化plotly

2019-05-10 11:13:19

分析工具Java

2019-05-23 08:08:33

MySQL數(shù)據(jù)庫DBA

2011-11-03 10:45:09

京東性能瓶頸

2023-11-08 14:03:47

數(shù)據(jù)可視化數(shù)字化轉(zhuǎn)型

2020-03-11 14:39:26

數(shù)據(jù)可視化地圖可視化地理信息

2018-11-21 14:38:09

分析在數(shù)據(jù)電影

2024-12-24 12:00:00

Matplotlib可視化分析Python

2024-04-01 11:53:42

PlotlyPython數(shù)據(jù)可視化
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 欧美成人免费在线视频 | 国产精品九九九 | 亚洲成人精品国产 | 中文字幕一区在线观看视频 | 亚洲乱码一区二区 | 国产一区二区三区不卡av | 一区二区三区免费 | 精品国产第一区二区三区 | 91xx在线观看 | 亚洲资源在线 | 盗摄精品av一区二区三区 | 91玖玖 | 久久日韩粉嫩一区二区三区 | 尤物在线精品视频 | 国产一区二区三区久久久久久久久 | 久久精品亚洲一区二区三区浴池 | 久久久片 | 日韩免费高清视频 | 香蕉婷婷 | 97超级碰碰 | 永久www成人看片 | 国产精品99久久久久久动医院 | 狠狠色狠狠色综合系列 | 国产精品久久久久久久久久久久冷 | 毛片区| 国产日韩精品一区二区 | 日韩一区二区福利视频 | 亚洲永久入口 | 亚洲不卡视频 | 精品久久久久香蕉网 | 中文字幕一区二区三区精彩视频 | 99热热99 | 女同久久另类99精品国产 | 国产精品美女久久久久久免费 | 日本精品一区二区三区在线观看视频 | 中文区中文字幕免费看 | 亚洲一区在线免费观看 | 国产精品1区2区3区 一区中文字幕 | 在线91 | 国产一级在线视频 | 天天操夜夜艹 |