n2g


Namen2g JSON
Version 0.3.3 PyPI version JSON
download
home_pagehttps://github.com/dmulyalin/N2G
SummaryNeed To Graph
upload_time2023-02-11 07:38:48
maintainerDenis Mulyalin
docs_urlNone
authorDenis Mulyalin
requires_python>=3.7,<4.0
licenseMIT
keywords diagramming graphing networks
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            [![Downloads](https://pepy.tech/badge/n2g)](https://pepy.tech/project/n2g)
[![Documentation Status](https://readthedocs.org/projects/n2g/badge/?version=latest)](https://n2g.readthedocs.io/en/latest/?badge=latest)

# Need To Graph

N2G is a library to generate diagrams in [yWorks](https://www.yworks.com/) graphml or [Diagrams](https://www.diagrams.net/)
drawio formats or produce JSON data compatible with [3d-force-graph JSON input syntax](https://github.com/vasturiano/3d-force-graph#input-json-syntax)
allowing 3D visualization.

<details><summary>Demo</summary>
<img src="example.gif">
</details>

## Why?

To save your time on producing consistently looking, editable diagrams of arbitrary size and complexity in a programmatic way helping to satisfy your "Need To Graph" desire.

## How?

Not a secret that many applications use XML structured text to save their diagrams content, then why not to do the opposite - produce XML structured text that applications can open and understand and work with. N2G does exactly that, it takes structured data - csv, dictionary, list or api calls and gives back XML text that can be opened and edited by application of choice.

## What?

All formats supported so far have very similar API capable of:

* adding nodes and links with various attributes such as shape, labels, urls, data, styles
* bulk graph creation using from_x methods supporting lists, dictionaries or csv data
* existing nodes and links attributes manipulation and update
* loading existing XML diagram files for processing and modification
* deletion of nodes and links from diagrams
* comparing two diagrams to highlight the difference between them
* layout your diagram with algorithms available in [igraph](https://igraph.org/2020/02/14/igraph-0.8.0-python.html) library
* returning results in text format or saving directly into the file

Reference [documentation](https://n2g.readthedocs.io/en/0.1.2/index.html) for more information.

## What it's not?

N2G is not a magic bullet that will produce perfect diagrams for you, it can help to simplify the process of adding elements to your diagrams. However, (manual) efforts required to put all the elements in positions where they will satisfy your inner sense of perfection, as a result, keep in mind that (normally) the more elements you have on your diagram, the more efforts required to make it looks good.

Quite unlikely it would ever be a tool with support of all capabilities available in subject applications, however, feature requests are welcomed.

## Example

```python
from N2G import yed_diagram

diagram = yed_diagram()
sample_list_graph = [
    {'source': {'id': 'SW1', 'top_label': 'CORE', 'bottom_label': '1,1,1,1'}, 'src_label': 'Gig0/0', 'target': 'R1', 'trgt_label': 'Gig0/1'},
    {'source': {'id': 'R2', 'top_label': 'DC-PE'}, 'src_label': 'Gig0/0', 'target': 'SW1', 'trgt_label': 'Gig0/2'},
    {'source': {'id':'R3', 'bottom_label': '1.1.1.3'}, 'src_label': 'Gig0/0', 'target': 'SW1', 'trgt_label': 'Gig0/3'},
    {'source': 'SW1', 'src_label': 'Gig0/4', 'target': 'R4', 'trgt_label': 'Gig0/1'},
    {'source': 'SW1', 'src_label': 'Gig0/5', 'target': 'R5', 'trgt_label': 'Gig0/7'},
    {'source': 'SW1', 'src_label': 'Gig0/6', 'target': 'R6', 'trgt_label': 'Gig0/11'}
]
diagram.from_list(sample_list_graph)
diagram.dump_file(filename="Sample_graph.graphml", folder="./")
```

# Disclaimer

Author of this module not affiliated with any of the application Vendors mentioned so far. The choice of formats to support was primarily driven by the fact of how much functionality available in particular application for free. Moreover, this module does not use any aforementioned (diagramming) applications in any programmatic way to produce its results, in other words, none of the aforementioned applications required to be installed on the system for this (N2G) module to work.

# Contributions
Feel free to submit an issue, to report a bug or ask a question, feature requests are welcomed or [buy](https://paypal.me/dmulyalin) Author a coffee

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/dmulyalin/N2G",
    "name": "n2g",
    "maintainer": "Denis Mulyalin",
    "docs_url": null,
    "requires_python": ">=3.7,<4.0",
    "maintainer_email": "d.mulyalin@gmail.com",
    "keywords": "Diagramming,Graphing,Networks",
    "author": "Denis Mulyalin",
    "author_email": "d.mulyalin@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/89/d6/d5bc677554fa7708b2f7cb425e99a7a7a76a86240e1261b35502b24667ca/N2G-0.3.3.tar.gz",
    "platform": null,
    "description": "[![Downloads](https://pepy.tech/badge/n2g)](https://pepy.tech/project/n2g)\n[![Documentation Status](https://readthedocs.org/projects/n2g/badge/?version=latest)](https://n2g.readthedocs.io/en/latest/?badge=latest)\n\n# Need To Graph\n\nN2G is a library to generate diagrams in [yWorks](https://www.yworks.com/) graphml or [Diagrams](https://www.diagrams.net/)\ndrawio formats or produce JSON data compatible with [3d-force-graph JSON input syntax](https://github.com/vasturiano/3d-force-graph#input-json-syntax)\nallowing 3D visualization.\n\n<details><summary>Demo</summary>\n<img src=\"example.gif\">\n</details>\n\n## Why?\n\nTo save your time on producing consistently looking, editable diagrams of arbitrary size and complexity in a programmatic way helping to satisfy your \"Need To Graph\" desire.\n\n## How?\n\nNot a secret that many applications use XML structured text to save their diagrams content, then why not to do the opposite - produce XML structured text that applications can open and understand and work with. N2G does exactly that, it takes structured data - csv, dictionary, list or api calls and gives back XML text that can be opened and edited by application of choice.\n\n## What?\n\nAll formats supported so far have very similar API capable of:\n\n* adding nodes and links with various attributes such as shape, labels, urls, data, styles\n* bulk graph creation using from_x methods supporting lists, dictionaries or csv data\n* existing nodes and links attributes manipulation and update\n* loading existing XML diagram files for processing and modification\n* deletion of nodes and links from diagrams\n* comparing two diagrams to highlight the difference between them\n* layout your diagram with algorithms available in [igraph](https://igraph.org/2020/02/14/igraph-0.8.0-python.html) library\n* returning results in text format or saving directly into the file\n\nReference [documentation](https://n2g.readthedocs.io/en/0.1.2/index.html) for more information.\n\n## What it's not?\n\nN2G is not a magic bullet that will produce perfect diagrams for you, it can help to simplify the process of adding elements to your diagrams. However, (manual) efforts required to put all the elements in positions where they will satisfy your inner sense of perfection, as a result, keep in mind that (normally) the more elements you have on your diagram, the more efforts required to make it looks good.\n\nQuite unlikely it would ever be a tool with support of all capabilities available in subject applications, however, feature requests are welcomed.\n\n## Example\n\n```python\nfrom N2G import yed_diagram\n\ndiagram = yed_diagram()\nsample_list_graph = [\n    {'source': {'id': 'SW1', 'top_label': 'CORE', 'bottom_label': '1,1,1,1'}, 'src_label': 'Gig0/0', 'target': 'R1', 'trgt_label': 'Gig0/1'},\n    {'source': {'id': 'R2', 'top_label': 'DC-PE'}, 'src_label': 'Gig0/0', 'target': 'SW1', 'trgt_label': 'Gig0/2'},\n    {'source': {'id':'R3', 'bottom_label': '1.1.1.3'}, 'src_label': 'Gig0/0', 'target': 'SW1', 'trgt_label': 'Gig0/3'},\n    {'source': 'SW1', 'src_label': 'Gig0/4', 'target': 'R4', 'trgt_label': 'Gig0/1'},\n    {'source': 'SW1', 'src_label': 'Gig0/5', 'target': 'R5', 'trgt_label': 'Gig0/7'},\n    {'source': 'SW1', 'src_label': 'Gig0/6', 'target': 'R6', 'trgt_label': 'Gig0/11'}\n]\ndiagram.from_list(sample_list_graph)\ndiagram.dump_file(filename=\"Sample_graph.graphml\", folder=\"./\")\n```\n\n# Disclaimer\n\nAuthor of this module not affiliated with any of the application Vendors mentioned so far. The choice of formats to support was primarily driven by the fact of how much functionality available in particular application for free. Moreover, this module does not use any aforementioned (diagramming) applications in any programmatic way to produce its results, in other words, none of the aforementioned applications required to be installed on the system for this (N2G) module to work.\n\n# Contributions\nFeel free to submit an issue, to report a bug or ask a question, feature requests are welcomed or [buy](https://paypal.me/dmulyalin) Author a coffee\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Need To Graph",
    "version": "0.3.3",
    "split_keywords": [
        "diagramming",
        "graphing",
        "networks"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "597a4213c9c5efdc5f4f85b73819128108186ec1d1b8252bf85087608b331f6d",
                "md5": "4869db7f6e5dc9194f71d4bb7f945c28",
                "sha256": "20e942c4d0de4412d03fd75e87189304e7c15fc87ab172fb01209eb19b782554"
            },
            "downloads": -1,
            "filename": "N2G-0.3.3-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "4869db7f6e5dc9194f71d4bb7f945c28",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.7,<4.0",
            "size": 481194,
            "upload_time": "2023-02-11T07:38:45",
            "upload_time_iso_8601": "2023-02-11T07:38:45.816630Z",
            "url": "https://files.pythonhosted.org/packages/59/7a/4213c9c5efdc5f4f85b73819128108186ec1d1b8252bf85087608b331f6d/N2G-0.3.3-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "89d6d5bc677554fa7708b2f7cb425e99a7a7a76a86240e1261b35502b24667ca",
                "md5": "746ea2255573f55cb15ea0fdfdac8a11",
                "sha256": "e19d955291c6baf5bd917c0def1ea1f1b2b9aab00131134fd0cb86d0e227f573"
            },
            "downloads": -1,
            "filename": "N2G-0.3.3.tar.gz",
            "has_sig": false,
            "md5_digest": "746ea2255573f55cb15ea0fdfdac8a11",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.7,<4.0",
            "size": 462073,
            "upload_time": "2023-02-11T07:38:48",
            "upload_time_iso_8601": "2023-02-11T07:38:48.731573Z",
            "url": "https://files.pythonhosted.org/packages/89/d6/d5bc677554fa7708b2f7cb425e99a7a7a76a86240e1261b35502b24667ca/N2G-0.3.3.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-02-11 07:38:48",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "github_user": "dmulyalin",
    "github_project": "N2G",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "n2g"
}
        
Elapsed time: 0.07644s