Metadata-Version: 2.1
Name: adbnx-adapter
Version: 2.0.0
Summary: Convert ArangoDB graphs to NetworkX & vice-versa.
Home-page: https://github.com/arangoml/networkx-adapter
Author: ArangoDB
Author-email: rajiv@arangodb.com
License: Apache Software License
Description: # ArangoDB-Networkx Adapter
        [![build](https://github.com/arangoml/networkx-adapter/actions/workflows/build.yml/badge.svg?branch=master)](https://github.com/arangoml/networkx-adapter/actions/workflows/build.yml)
        [![CodeQL](https://github.com/arangoml/networkx-adapter/actions/workflows/analyze.yml/badge.svg?branch=master)](https://github.com/arangoml/networkx-adapter/actions/workflows/analyze.yml)
        [![Coverage Status](https://coveralls.io/repos/github/arangoml/networkx-adapter/badge.svg?branch=master)](https://coveralls.io/github/arangoml/networkx-adapter)
        [![Last commit](https://img.shields.io/github/last-commit/arangoml/networkx-adapter)](https://github.com/arangoml/networkx-adapter/commits/master)
        
        [![PyPI version badge](https://img.shields.io/pypi/v/adbnx-adapter?color=3775A9&style=for-the-badge&logo=pypi&logoColor=FFD43B)](https://pypi.org/project/adbnx-adapter/)
        [![Python versions badge](https://img.shields.io/pypi/pyversions/adbnx-adapter?color=3776AB&style=for-the-badge&logo=python&logoColor=FFD43B)](https://pypi.org/project/adbnx-adapter/)
        
        [![License](https://img.shields.io/github/license/arangoml/networkx-adapter?color=9E2165&style=for-the-badge)](https://github.com/arangoml/networkx-adapter/blob/master/LICENSE)
        [![Code style: black](https://img.shields.io/static/v1?style=for-the-badge&label=code%20style&message=black&color=black)](https://github.com/psf/black)
        [![Downloads](https://img.shields.io/badge/dynamic/json?style=for-the-badge&color=282661&label=Downloads&query=total_downloads&url=https://api.pepy.tech/api/projects/adbnx-adapter)](https://pepy.tech/project/adbnx-adapter)
        
        ![](https://raw.githubusercontent.com/arangoml/networkx-adapter/1.0.0/examples/assets/logos/ArangoDB_logo.png)
        
        ![](https://raw.githubusercontent.com/arangoml/networkx-adapter/1.0.0/examples/assets/logos/networkx_logo.svg)
        
        The ArangoDB-Networkx Adapter exports Graphs from ArangoDB, a multi-model Graph Database, into NetworkX, the swiss army knife for graph analysis with python, and vice-versa.
        
        
        
        ## About NetworkX
        
        Networkx is a commonly used tool for analysis of network-data. If your analytics use cases require the use of all your graph data, for example, to summarize graph structure, or answer global path traversal queries, then using the ArangoDB Pregel API is recommended. If your analysis pertains to a subgraph, then you may be interested in getting the Networkx representation of the subgraph for one of the following reasons:
        
            1. An algorithm for your use case is available in Networkx.
            2. A library that you want to use for your use case works with Networkx Graphs as input.
        
        ##  Quickstart
        
        Get Started on Colab: <a href="https://colab.research.google.com/github/arangoml/networkx-adapter/blob/master/examples/ArangoDB_NetworkxAdapter.ipynb" target="_parent"><img src="https://colab.research.google.com/assets/colab-badge.svg" alt="Open In Colab"/></a>
        
        
        ```py
        import networkx as nx
        from adbnx_adapter.adbnx_adapter import ArangoDB_Networkx_Adapter
        
        con = {
            "hostname": "localhost",
            "protocol": "http",
            "port": 8529,
            "username": "root",
            "password": "rootpassword",
            "dbName": "_system",
        }
        
        adbnx_adapter = ArangoDB_Networkx_Adapter(con)
        
        # (Assume ArangoDB fraud-detection data dump is imported)
        
        fraud_nx_g = adbnx_adapter.arangodb_graph_to_networkx("fraud-detection")
        fraud_nx_g_2 = adbnx_adapter.arangodb_collections_to_networkx(
                "fraud-detection", 
                {"account", "bank", "branch", "Class", "customer"},
                {"accountHolder", "Relationship", "transaction"}
        )
        
        
        grid_nx_g = nx.grid_2d_graph(5, 5)
        grid_edge_definitions = [
            {
                "edge_collection": "to",
                "from_vertex_collections": ["Grid_Node"],
                "to_vertex_collections": ["Grid_Node"],
            }
        ]
        adb_g = adbnx_adapter.networkx_to_arangodb("Grid", grid_nx_g, grid_edge_definitions)
        ```
        
        ##  Development & Testing
        
        Prerequisite: `arangorestore` must be installed
        
        1. `git clone https://github.com/arangoml/networkx-adapter.git`
        2. `cd networkx-adapter`
        3. `python -m venv .venv`
        4. `source .venv/bin/activate` (MacOS) or `.venv/scripts/activate` (Windows)
        5. `cd adbnx_adapter`
        6. `pip install -e . pytest`
        7. `pytest`
            * If you encounter `ModuleNotFoundError`, try closing & relaunching your virtual environment by running `deactivate` in your terminal & restarting from Step 4.
        
Platform: UNKNOWN
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Topic :: Utilities
Classifier: Typing :: Typed
Requires-Python: >=3.6
Description-Content-Type: text/markdown
