Allows Python code execution inside of graphviz diagrams
graph python_graph {
{{
import math
value = 0.5
sin = math.sin(value)
cos = math.cos(value)
}}
A [label="{{= value }}"];
B [label="{{= sin }}"];
C [label="{{= cos }}"];
A -- B [headlabel="sin"];
A -- C [headlabel="cos"];
}
pip install graphviz-py
Important: Make sure graphviz is installed! See graphviz installation instructions.
graphviz-py -Tsvg example/example.py.dot -o output.svg
graphviz-py -Tpng example/example.py.dot -o output.png
echo 'digraph { A -> B [label="{{= 38 * 73 }}"] }' | graphviz-py -Tsvg > output.svg
graphviz-py passes all unknown arguments to graphviz. So you can use all graphviz arguments.
graphviz-py -Tsvg -a myvalue=5 example/variable_example.py.dot -o output.svg
Here we pass a variable called "myvalue" with the value 5
Please keep in mind that graphviz-py executes all Python code in the diagram. So make sure that your diagrams do not include harmful code.
- Compartibility with asciidoctor-diagram (Status: Implemented & Approved, waiting for merging)
# graphviz-py --help
usage: graphviz-py [-h] [-v] [-d] [-a ARGUMENT] [files [files ...]]
graphviz-py diagram builder
positional arguments:
files the paths to the graphviz-py files
optional arguments:
-h, --help show this help message and exit
-v, --version show program's version number and exit
-d, --debug show debug information
-a ARGUMENT, --argument ARGUMENT