Skip to main content

Graph and network visualization utilities extending graphviz and networkx

Project description

python-graphviz-plus

A set of graph and network visualization utilities that extend graphviz, networkx, and pandas. Highly optimized for generating clean, elegant, and styled graphs in both Jupyter Notebooks and standard Python scripts.

Github

https://github.com/Santt997/python-graphviz-plus

Key Features

  • AdjacencyList: Parse edge lists (traditional ll representation) or dictionaries of neighbor tuples. Easily convert these structures into Pandas DataFrames for quick inspection and tabular formatting.
  • BlackNeatoGraph: An elegant Graphviz-based class using the neato layout engine. Renders beautiful dark-themed networks with circular nodes, custom positioning (pos), overlap prevention, and automatic styling. Provides direct helpers to check graph properties (e.g., maximum/minimum degrees, regularity).
  • ValencyList: A specialized helper class to calculate, analyze, and manage the degrees (valency) of all nodes in a graph. Features handshake lemma validation, regular graph detection, and sorted list exports.

Installation

You can install python-graphviz-plus directly from PyPI:

pip install python-graphviz-plus

Quick Start

1. Generating a Black Neato Graph

from graph import BlackNeatoGraph

# Define an edge list (source, destination)
edges = [
    ("A", "B"),
    ("B", "C"),
    ("C", "A"),
    ("C", "D")
]

# Position mapping for nodes (optional)
positions = [
    ("A", "0,0!"),
    ("B", "1,1!"),
    ("C", "2,0!"),
    ("D", "3,-1!")
]

# Create and render the black graph
g = BlackNeatoGraph(ll=edges, lp=positions, name="MyBeautifulGraph")

# Inside a Jupyter Notebook, it will render inline:
# g
# Or save to a file:
g.render("graph_output", format="png", cleanup=True)

2. Inspecting Node Valencies

from graph import ValencyList

# Analyze the valencies from the edge list
valencies = ValencyList(edges)

print("Degrees mapping:", valencies.raw())
print("Is regular graph?", valencies.is_regular())
print("Handshake lemma holds?", valencies.sum_check())

3. Converting to a Tabular Adjacency Matrix / DataFrame

from graph import AdjacencyList

adj = AdjacencyList(edges)
df = adj.to_dataframe()

# Display as pandas DataFrame
print(df)

Requirements

  • Python >= 3.8
  • graphviz
  • networkx
  • pandas

Note: Ensure that the Graphviz system binaries (dot, neato, etc.) are installed on your system path.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

python_graphviz_plus-0.1.1.tar.gz (4.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

python_graphviz_plus-0.1.1-py3-none-any.whl (5.7 kB view details)

Uploaded Python 3

File details

Details for the file python_graphviz_plus-0.1.1.tar.gz.

File metadata

  • Download URL: python_graphviz_plus-0.1.1.tar.gz
  • Upload date:
  • Size: 4.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for python_graphviz_plus-0.1.1.tar.gz
Algorithm Hash digest
SHA256 7d419988be6d4121fefa475b90f0ae96a293e0146677ff41fc0fb25757d1972a
MD5 2878d5d2c0b485faf7aacd9852099981
BLAKE2b-256 9c4041279e66b0bae5193b9ac832e83ab63a64c290c94a8fe343263936572cbc

See more details on using hashes here.

File details

Details for the file python_graphviz_plus-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for python_graphviz_plus-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 407251e807a0430015115b62ef983028dc7fd1810749d964cdc4f729b6c657fe
MD5 97edaed357b048442d192a94f89d8731
BLAKE2b-256 8e27245e835b2c3353ca4d984dd2e9d32006da19a361631b50d330a4d8aae351

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page