Documentation Index¶
Python Call Graph¶
Welcome! Python Call Graph is a Python module that creates call graph visualizations for Python applications.
This repo used to be pycallgraph
which is still hosted at pypi link.
The uploader makes no representations of their contribution, and merely wanted this to work in python 3.5; with a goal to porting it to 3.11 and 3.12
[! NOTE] Please give more ideas for problems or further use-cases for this repo. I am really glad folks like it, but it’s mostly the original author work, and I don’t yet know what more to add to this.
Screenshots¶
Click on the images below to see a larger version and the source code that generated them.
Project Status¶
The latest version is 2.1.1 which was released on 2024-03-31. The latest version has been tested running on Python versions 3.8 - 3.12
The project lives on GitHub, where you can report issues, contribute to the project by forking the project then creating a pull request, or just browse the source code.
The documentation needs some work stiil. Feel free to contribute :smile:
Features¶
Support for Python 3.8 - 3.12.
Static visualizations of the call graph using various tools such as Graphviz and Gephi.
Execute pycallgraph from the command line or import it in your code.
Customisable colors. You can programatically set the colors based on number of calls, time taken, memory usage, etc.
Modules can be visually grouped together.
Easily extendable to create your own output formats.
Quick Start¶
Installation is easy as
pip install python-call-graph
You can either use the command-line interface for a quick visualization of your Python script, or the pycallgraph module for more fine-grained settings.
The following examples specify graphviz as the outputter, so it’s required to be installed. They will generate a file called pycallgraph.png
.
The command-line method of running pycallgraph is¶
pycallgraph graphviz -- ./mypythonscript.py
A simple use of the API is¶
from pycallgraph import PyCallGraph
from pycallgraph.output import GraphvizOutput
with PyCallGraph(output=GraphvizOutput()):
code_to_profile()
Documentation¶
Feel free to browse the documentation of pycallgraph for the usage guide and API reference.