Skip to main content

A simple graph visualization tool

Project description

Graph Visualization for Python by Neo4j

Latest version PyPI downloads month Python versions Documentation Discord Community forum License

neo4j-viz is a Python package for creating interactive graph visualizations.

The output is of type IPython.display.HTML and can be viewed directly in a Jupyter Notebook or Streamlit application. Alternatively, you can export the output to a file and view it in a web browser.

The package wraps the Neo4j Visualization JavaScript library (NVL).

Example Graph

Some notable features

  • Easy to import graphs represented as:
    • projections in the Neo4j Graph Data Science (GDS) library
    • graphs from Neo4j query results
    • pandas DataFrames
  • Node features:
    • Sizing
    • Colors
    • Captions
    • Pinning
    • On hover tooltip
  • Relationship features:
    • Colors
    • Captions
    • On hover tooltip
  • Graph features:
    • Zooming
    • Panning
    • Moving nodes
    • Using different layouts
  • Additional convenience functionality for:
    • Resizing nodes, optionally including scale normalization
    • Coloring nodes based on a property
    • Toggle whether nodes should be pinned or not

Please note that this list is by no means exhaustive.

Getting started

Installation

Simply install with pip:

pip install neo4j-viz

Basic usage

We will use a small toy graph representing the purchase history of a few people and products.

We start by instantiating the Nodes and Relationships we want in our graph. The only mandatory fields for a node are the "id", and "source" and "target" for a relationship. But the other fields can optionally be used to customize the appearance of the nodes and relationships in the visualization.

Lastly we create a VisualizationGraph object with the nodes and relationships we created, and call its render method to display the graph.

from neo4j_viz import Node, Relationship, VisualizationGraph

nodes = [
    Node(id=0, size=10, caption="Person"),
    Node(id=1, size=10, caption="Product"),
    Node(id=2, size=20, caption="Product"),
    Node(id=3, size=10, caption="Person"),
    Node(id=4, size=10, caption="Product"),
]
relationships = [
    Relationship(
        source=0,
        target=1,
        caption="BUYS",
    ),
    Relationship(
        source=0,
        target=2,
        caption="BUYS",
    ),
    Relationship(
        source=3,
        target=2,
        caption="BUYS",
    ),
]

VG = VisualizationGraph(nodes=nodes, relationships=relationships)

VG.render()

This will return a IPython.display.HTML object that can be rendered in a Jupyter Notebook or streamlit application.

Please refer to the documentation for more details on the API and usage.

Examples

For more extensive examples, including how to import graphs from Neo4j GDS projections and Pandas DataFrames, checkout the tutorials chapter in the documentation.

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

neo4j_viz-1.2.0.tar.gz (2.2 MB view details)

Uploaded Source

Built Distribution

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

neo4j_viz-1.2.0-py3-none-any.whl (2.2 MB view details)

Uploaded Python 3

File details

Details for the file neo4j_viz-1.2.0.tar.gz.

File metadata

  • Download URL: neo4j_viz-1.2.0.tar.gz
  • Upload date:
  • Size: 2.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for neo4j_viz-1.2.0.tar.gz
Algorithm Hash digest
SHA256 5fe3b1584707cb5784fb5f6d94b8ced0a507f9a92af373415dd2e408b8be6e5a
MD5 c269642e127265151776037cc09863d3
BLAKE2b-256 1fc833339c53c98bdd5ff0fd473f522ad3494a4ac82d56e05e5c7f6a7ffc6dad

See more details on using hashes here.

File details

Details for the file neo4j_viz-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: neo4j_viz-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 2.2 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for neo4j_viz-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fe08dd4a3a6f2e5b2ab0214d2d59c1fac7a302695ff6e2712da0c4de00bd73aa
MD5 45423c1d4d74e9fa69eb4458da682e49
BLAKE2b-256 f07781c5d2e9c38eeac534821f1f21e1f8dacd79b3482b69172fc44d1e2a9dd2

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