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.

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.0.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.0-py3-none-any.whl (5.7 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for python_graphviz_plus-0.1.0.tar.gz
Algorithm Hash digest
SHA256 ca4b28c28ac947efc4b1e6862fef5c26e981c369698a3d9db2e55595a6a3d796
MD5 fa74be44aecc09f87f59de36adb758d3
BLAKE2b-256 d716038bbf904302a2837530b241f185a07df68617057c7cf04689aa5aa02499

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for python_graphviz_plus-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 20dcee59f882af839921129e04372f788ba4e328354e52e90e51b0b7996007e5
MD5 6baa13ddf3a0ebb7cfe5a3fd4b396321
BLAKE2b-256 5e66eca6848ad9d3774d6095689dde99dfbebc313de2208fe3f6a69aa3b9bc3a

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