千锋教育-做有情怀、有良心、有品质的职业教育机构

400-811-9990
手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

上海
  • 北京
  • 郑州
  • 武汉
  • 成都
  • 西安
  • 沈阳
  • 广州
  • 南京
  • 深圳
  • 大连
  • 青岛
  • 杭州
  • 重庆
当前位置:长沙千锋IT培训  >  技术干货  >  Python 性能剖分工具

Python 性能剖分工具

来源:千锋教育
发布人:xqq
时间: 2023-11-08 16:17:02

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

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://www.mobiletrain.org/

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。

猜你喜欢LIKE

python实现WSGI的框架

2023-11-13

python打开文本文件有哪些方法?

2023-11-13

python使用loguru操作日志

2023-11-13

最新文章NEW

python-=是什么意思

2023-11-13

pythonre是什么?

2023-11-13

python列表追加元素出错的解决

2023-11-13

相关推荐HOT

更多>>

快速通道 更多>>

最新开班信息 更多>>

网友热搜 更多>>