Skip to main content

Graphinate. Data to Graphs.

Project description

Graphinate. Data to Graphs.

Graphinate. Data to Graphs.

Package PyPI - version PyPI - Status PyPI - Python Version PyPI - Downloads
GitHub GitHub repo size GitHub last commit (by committer) Contributors
CI/CD Tests Publish Publish Docs
Scans Quality Gate Status Security Rating Maintainability Rating Reliability Rating
Lines of Code Vulnerabilities Bugs
Coverage Codacy Badge

[!WARNING]

UNDER DEVELOPMENT


Introduction

What is Graphinate?

Graphinate is a python library that aims to simplify the generation of Graph Data Structures from Data Sources.

It can help create an efficient retrieval pipeline from a given data source, while also enabling the developer to easily map data payloads and hierarchies to a Graph.

In addition, there are several modes of output to enable examination of the Graph, and it's content.

Graphinate utilizes and builds upon the excellent NetworkX.

Links


Quick Start

Install

Graphinate is available on PyPI:

pip install graphinate

To install with server support

pip install graphinate[server]

Graphinate officially supports Python 3.9+.

Example

import graphinate

N: int = 8

# Define GraphModel
graph_model = graphinate.model(name="Octagonal Graph")


# Register edges supplier function
@graph_model.edge()
def edge():
    for i in range(N):
        yield {'source': i, 'target': i + 1}
    yield {'source': N, 'target': 0}


# Materialize the GraphModel
graphinate.materialize(graph_model)

[!NOTE]

graphinate.GraphModel class

This class is used to declaratively register Edge and/or Node data supplier functions by using decorators.

graphinate.materialize function

This function can be used to easily generate an output from a GraphModel instance. By default it will prompt the user to choose the output format, using a popup dialog.

CLI

Commands

Usage: python -m graphinate [OPTIONS] COMMAND [ARGS]...

Options:
  --help  Show this message and exit.

Commands:
  save
  server

Save

Usage: python -m graphinate save [OPTIONS]

Options:
  -m, --model MODEL  A GraphModel instance reference {module-
                     name}:{GraphModel-instance-variable-name} For example,
                     given var `model=GraphModel()` defined in app.py file,
                     then the  reference should be app:model
  --help             Show this message and exit.

Server

Usage: python -m graphinate server [OPTIONS]

Options:
  -m, --model MODEL   A GraphModel instance reference {module-
                      name}:{GraphModel-instance-variable-name} For example,
                      given var `model=GraphModel()` defined in app.py file,
                      then the  reference should be app:model
  -p, --port INTEGER  Port number.
  --help              Show this message and exit.

Gallery

Python AST

d3_graph_ast

GitHub Repository

repo_graph

Python AST - 3D Force-Directed Animation

AST 3D Force animation

Development

Ruff

ruff check src

Test

Standard (cobertura) XML Coverage Report

 python -m pytest ./tests --cov=./src --cov-branch --doctest-modules --cov-report=xml --junitxml=test_results.xml

HTML Coverage Report

 python -m pytest tests --cov=src --cov-branch --doctest-modules --cov-report=html --junitxml=test_results.xml

Docs

test

python -m mkdocs serve

build

python -m mkdocs build

Acknowledgements

Dependencies

Python

Click Logo. Loguru Logo. matplotlib Logo. NetworkX Logo. Strawberry GraphQL Logo.

Javascript and HTML

3D Force-Directed Graph Logo. Graphql Voyager Logo.

Dev Tools

Hatch logo. pytest logo. Ruff logo.

IDE

PyCharm logo.

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

graphinate-0.2.1.tar.gz (247.5 kB view details)

Uploaded Source

Built Distribution

graphinate-0.2.1-py3-none-any.whl (71.8 kB view details)

Uploaded Python 3

File details

Details for the file graphinate-0.2.1.tar.gz.

File metadata

  • Download URL: graphinate-0.2.1.tar.gz
  • Upload date:
  • Size: 247.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.18

File hashes

Hashes for graphinate-0.2.1.tar.gz
Algorithm Hash digest
SHA256 fabac89b9ae654c8263247908f3c72076487bbda700194e89d5f801fd5aa5ffa
MD5 4e6b1d22274ced9cb8495c5c04f1a4d1
BLAKE2b-256 dff7430c5ae78f88215db14c0b4934862c6bd51e997c1639787dc062941e78c1

See more details on using hashes here.

File details

Details for the file graphinate-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: graphinate-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 71.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.18

File hashes

Hashes for graphinate-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 3333646882c9d0dccce120baa07b84f8fe2452549410c4f39b1adb270f6778ee
MD5 5c6c293656c6b626ef2d3ff578c6b65f
BLAKE2b-256 27b4637dd3c183111b94854785268818a7208c92b0209b8184aa720b2648027d

See more details on using hashes here.

Supported by

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