百科狗-知识改变命运!
--

Python 性能剖分工具

是丫丫呀1年前 (2023-11-21)阅读数 8#技术干货
文章标签函数

眼看着项目即将完成,却被测试人员告知没有通过性能测试,这种情况在开发中屡见不鲜。接下来的工作就是加班加点地找出性能瓶颈,然后进行优化,再进行性能测试,如此这般周而复始直到通过性能测试。尽管丰富的工作经验有助于性能优化,但只有科学地应用工具才能在最短的时间内找出最佳优化粒度的瓶颈代码段,达到事半功倍的效果。

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性能剖分工具,希望对大家有所帮助,如果想要了解更多Python相关知识,请关注IT培训机构:开发教育。http://www.baikegou.com/

鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com

免责声明:我们致力于保护作者版权,注重分享,当前被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!邮箱:344225443@qq.com)

图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

内容声明:本文中引用的各种信息及资料(包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主体(包括但不限于公司、媒体、协会等机构)的官方网站或公开发表的信息。部分内容参考包括:(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供参考使用,不准确地方联系删除处理!本站为非盈利性质站点,本着为中国教育事业出一份力,发布内容不收取任何费用也不接任何广告!)