天天看点

pycallgraph 追踪Python函数内部调用

<a href="#%E5%AE%89%E8%A3%85">安装</a>

<a href="#%E5%AE%89%E8%A3%85pycallgraph">安装pycallgraph</a>

<a href="#%E5%AE%89%E8%A3%85%E4%BE%9D%E8%B5%96">安装依赖</a>

<a href="#%E4%BD%BF%E7%94%A8">使用</a>

<a href="#%E5%BE%85%E6%B5%8B%E8%84%9A%E6%9C%AC">待测脚本</a>

<a href="#%E8%BF%BD%E8%B8%AA%E8%84%9A%E6%9C%AC">追踪脚本</a>

<a href="#%E8%BF%BD%E8%B8%AA%E7%BB%93%E6%9E%9C">追踪结果</a>

<a href="#%E9%AB%98%E7%BA%A7%E7%AF%87">高级篇</a>

<a href="#%E9%9A%90%E8%97%8F%E7%A7%81%E5%AF%86%E5%87%BD%E6%95%B0">隐藏私密函数</a>

<a href="#%E6%8E%A7%E5%88%B6%E6%9C%80%E5%A4%A7%E8%BF%BD%E8%B8%AA%E6%B7%B1%E5%BA%A6">控制最大追踪深度</a>

<a href="#%E6%80%BB%E7%BB%93">总结</a>

GitHub上好代码真的是太多了,名副其实的一个宝藏。但是最近自己也反思了一下,为什么别人的代码看起来那么的费劲。很多时候还不得要领,博主的笨方法就是先看下代码的结构,目录。然后就从程序的入口出发了,一步步的往底层去追溯,但是因为忒懒,也没有超大的临时记忆空间,于是代码跟着跟着就跑偏了,这也是看别人代码的时候效率不高的主要原因。

幸运的是,发现了一款神器,pycallgraph,其作用就是追踪函数的相互调用的情况,如此一来,对每个函数的的追踪将一览无余。

安装这个库是比较简单的,但是安装好了是不能用的。

pycallgraph 追踪Python函数内部调用

因为还需要一个图形库的依赖(graphviz), 这个依赖是著名的贝尔实验室的一位大牛写的一个命令行下的作图工具库。超赞。

graphviz2.38 画图库下载链接为:

<a href="http://www.softpedia.com/dyn-postdownload.php/adf89304319dca207ef04cd94d39e586/57ff4c63/1e6eb/4/1?tsf=0">http://www.softpedia.com/dyn-postdownload.php/adf89304319dca207ef04cd94d39e586/57ff4c63/1e6eb/4/1?tsf=0</a>

下载完之后,为了不出现之前的那个command命令实效。我们还得将graphviz的path添加到电脑的系统变量中。

具体做法:

系统属性-&gt;高级设置-&gt;环境变量-&gt;path-&gt;记得环境变量之间用英文的;号分隔开

配置好了上面的步骤之后,就可以正式的使用pycallgraph咯。为了方便演示,这里写了一段简单的脚本。

然后我们就可以使用pycallgraph来完成简单的追踪过程了。

运行完脚本后,此文件夹中的细节如下:

在成功的下载了一张百度的logo照片之后,我们不难发现,多了一个叫trace_detail.png 的文件。

如下:

pycallgraph 追踪Python函数内部调用

是不是感觉还不赖呢?函数之间的依赖关系,调用情况都可以得到很好的追溯。

所谓高级,就是附加了点小情况而已。无非加个过滤条件,控制一下函数调用的追踪深度。

如题,隐藏那些不想看到的函数的名称,这一点在某些情况下还是很好用的。

pycallgraph 追踪Python函数内部调用

这一点也很好理解了吧,待会看完图就更加清晰了。

pycallgraph 追踪Python函数内部调用

这次的文章没什么技术含量,但是确实很实用的一篇介绍性的文章。下次读代码遇到瓶颈的时候,不妨来尝试一把这个工具。相信会让你眼前一亮的。