Skip to content

Python library for generating dot programming language for creating graphviz graphs from python OO style code

License

Notifications You must be signed in to change notification settings

farkon00/pygraphv

Repository files navigation

Pygraphv

Pygraphv - python library for generating dot programming language for creating graphviz graphs from python OO style code.

Examples

Basic graph:

from pygraphv.graph import Graph
from pygraphv.node import Node
from pygraphv.style import GraphStyle

# Chose one of this
# You can look at difference in Graphviz docs
# digraph = Digraph("Digraph")
graph = Graph("Graph")

# Adds node with name A, that has child node B
a = Node("A")
graph.add_node(a)
graph.add_node(Node("B"), parent=a)

# Generates .dot file for your graph and saves it in "Your first graph.dot"
# And renders it to svg file, needs dot compiler installed and added to path
graph.render("Your first graph")

Styles:

from pygraphv.graph import Digraph
from pygraphv.style import *
from pygraphv.node import Node

# Now digraph example
# Only difference to regular graph is arrows at ends of connections
graph = Digraph("Graph", styles=[GraphStyle(bgcolor="lightblue"), GraphStyle(href="github.com/farkon00")])

# Adds node with name A, that has child node B
a = Node("A", styles=NodeStyle(color="red", shape="box"))
graph.add_node(a)
graph.add_node(Node("B"), label="Styled edge", parent=a, styles=EdgeStyle(arrowhead="box"))

# Generates .dot file for your graph and saves it in "Styles.dot"
# And renders it to svg file, needs dot compiler installed and added to path
graph.render("Styles")

Clusters:

from pygraphv.graph import Graph, Cluster
from pygraphv.style import *
from pygraphv.node import Node

graph = Graph("Graph")

# Adds node with name A, that has child node B
a = Node("A")
graph.add_node(a)
graph.add_node(Node("B"), parent=a)

# Creates cluster and adds cycle of 3 nodes, connected to node A

# Can be compressed to one style object
# But you can use GraphStyle on clusters
cluster = Cluster("Cluster", styles=(GraphStyle(bgcolor="lightgreen"), ClusterStyle(style="dotted")))

node1 = Node("1")
cluster.add_node(node1)
a.children.append(node1)
cluster.add_node(Node("2"), parent=node1)
cluster.add_node(Node("3"), parent=node1)
graph.add_node(node1.children[-1].node, parent=node1.children[-2].node)

graph.add_subgraph(cluster)

# Generates .dot file for your graph and saves it in "Clusters.dot"
# And renders it to svg file, needs dot compiler installed and added to path
graph.render("Clusters")

Subclassing

You may want to use subclassing to plot your tree.

from pygraphv.graph import Graph
from pygraphv.node import Node

class BTreeNode(Node):
    def __init__(self, left, right, value: int):
        super().__init__(str(value))
        self.left = left
        self.right = right
        if left is not None:
            self.children.append(left)
        if right is not None:
            self.children.append(right)

tree = Graph(name="BinaryTree")
tree.add_node(
    BTreeNode(
        BTreeNode(
            None, 
            BTreeNode(None, None, 69),
            42
        ),
        BTreeNode(
            BTreeNode(None, None, 34),
            BTreeNode(None, None, 35),
            420
        ),
        6969
    )
)

tree.render("Binary Tree")

About

Python library for generating dot programming language for creating graphviz graphs from python OO style code

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages