Name | neo4j-runway JSON |
Version |
0.14.0
JSON |
| download |
home_page | None |
Summary | A Python library that contains tools for data discovery, data model generation and ingestion for the Neo4j graph database. |
upload_time | 2024-11-04 14:01:19 |
maintainer | None |
docs_url | None |
author | Alex Gilmore |
requires_python | <4.0,>=3.10 |
license | Apache License, Version 2.0 |
keywords |
graph
neo4j
data model
|
VCS |
|
bugtrack_url |
|
requirements |
No requirements were recorded.
|
Travis-CI |
No Travis.
|
coveralls test coverage |
No coveralls.
|
# Neo4j Runway
Neo4j Runway is a Python library that simplifies the process of migrating your relational data into a graph. It provides tools that abstract communication with OpenAI to run discovery on your data and generate a data model, as well as tools to generate ingestion code and load your data into a Neo4j instance.
<img src="./docs/assets/images/neo4j-runway-logo.webp" width=300 height=400>
## Key Features
- **Data Discovery**: Harness OpenAI LLMs to provide valuable insights from your data
- **Graph Data Modeling**: Utilize OpenAI and the [Instructor](https://github.com/jxnl/instructor) Python library to create valid graph data models
- **Code Generation**: Generate ingestion code to easily load your data
- **Data Ingestion**: Load your data using Runway's built in implementation of [PyIngest](https://github.com/neo4j-field/pyingest) - Neo4j's popular ingestion tool
- **Exploratory Data Analysis**: Run analytics over your graph to discover potential data quality issues
## Requirements
Runway uses Graphviz to visualize data models. To enjoy this feature please download [graphviz](https://www.graphviz.org/download/).
You'll need a Neo4j instance to fully utilize Runway. Start up a free cloud hosted [Aura](https://console.neo4j.io) instance or download the [Neo4j Desktop app](https://neo4j.com/download/).
## Get Running in Minutes
Follow the steps below or check out any of the Neo4j Runway [end-to-end examples](https://github.com/a-s-g93/neo4j-runway/tree/main/examples/end_to_end)
```
pip install neo4j-runway
```
Now let's walk through a basic example.
Here we import the modules we'll be using.
```Python
from neo4j_runway import Discovery, GraphDataModeler, PyIngest, UserInput
from neo4j_runway.code_generation import PyIngestConfigGenerator
from neo4j_runway.llm.openai import OpenAIDiscoveryLLM, OpenAIDataModelingLLM
```
### Discovery
Now we...
- Define a general description of our data
- Provide brief descriptions of the columns of interest
- Provide any use cases we'd like our data model to address
- Load our csv via Runway's `load_local_files` function
```Python
data_directory = "../../../data/countries/"
data_dictionary = {
'id': 'unique id for a country.',
'name': 'the country name.',
'phone_code': 'country area code.',
'capital': 'the capital of the country.',
'currency_name': "name of the country's currency.",
'region': 'primary region of the country.',
'subregion': 'subregion location of the country.',
'timezones': 'timezones contained within the country borders.',
'latitude': 'the latitude coordinate of the country center.',
'longitude': 'the longitude coordinate of the country center.'
}
use_cases = [
"Which region contains the most subregions?",
"What currencies are most popular?",
"Which countries share timezones?"
]
data = load_local_files(data_directory=data_directory,
data_dictionary=data_dictionary,
general_description="This is data on countries and their attributes.",
use_cases=use_cases,
include_files=["countries.csv"])
```
We may also preview our csv data before running any processes
```python
data.tables[0].dataframe.head()
```
<div>
<table border="1" class="dataframe">
<thead>
<tr style="text-align: right;">
<th></th>
<th>id</th>
<th>name</th>
<th>phone_code</th>
<th>capital</th>
<th>currency_name</th>
<th>region</th>
<th>subregion</th>
<th>timezones</th>
<th>latitude</th>
<th>longitude</th>
</tr>
</thead>
<tbody>
<tr>
<th>0</th>
<td>1</td>
<td>Afghanistan</td>
<td>93</td>
<td>Kabul</td>
<td>Afghan afghani</td>
<td>Asia</td>
<td>Southern Asia</td>
<td>[{zoneName:'Asia\/Kabul',gmtOffset:16200,gmtOf...</td>
<td>33.000000</td>
<td>65.0</td>
</tr>
<tr>
<th>1</th>
<td>2</td>
<td>Aland Islands</td>
<td>+358-18</td>
<td>Mariehamn</td>
<td>Euro</td>
<td>Europe</td>
<td>Northern Europe</td>
<td>[{zoneName:'Europe\/Mariehamn',gmtOffset:7200,...</td>
<td>60.116667</td>
<td>19.9</td>
</tr>
<tr>
<th>2</th>
<td>3</td>
<td>Albania</td>
<td>355</td>
<td>Tirana</td>
<td>Albanian lek</td>
<td>Europe</td>
<td>Southern Europe</td>
<td>[{zoneName:'Europe\/Tirane',gmtOffset:3600,gmt...</td>
<td>41.000000</td>
<td>20.0</td>
</tr>
<tr>
<th>3</th>
<td>4</td>
<td>Algeria</td>
<td>213</td>
<td>Algiers</td>
<td>Algerian dinar</td>
<td>Africa</td>
<td>Northern Africa</td>
<td>[{zoneName:'Africa\/Algiers',gmtOffset:3600,gm...</td>
<td>28.000000</td>
<td>3.0</td>
</tr>
<tr>
<th>4</th>
<td>5</td>
<td>American Samoa</td>
<td>+1-684</td>
<td>Pago Pago</td>
<td>US Dollar</td>
<td>Oceania</td>
<td>Polynesia</td>
<td>[{zoneName:'Pacific\/Pago_Pago',gmtOffset:-396...</td>
<td>-14.333333</td>
<td>-170.0</td>
</tr>
</tbody>
</table>
</div>
We may then initialize our discovery and data modeling LLMs. By default we use GPT-4o and define our OpenAI API key in an environment variable.
```Python
llm_disc = OpenAIDiscoveryLLM(model_name='gpt-4o-mini-2024-07-18', model_params={"temperature": 0})
llm_dm = OpenAIDataModelingLLM(model_name='gpt-4o-2024-05-13', model_params={"temperature": 0.5})
```
And we run discovery on our data.
```Python
disc = Discovery(llm=llm_disc, data=data)disc.run()
disc.run(show_result=True, notebook=True)
```
### Preliminary Analysis of Country Data
#### Overall Data Characteristics:
1. **Data Size**: The dataset contains 250 entries (countries) and 10 attributes.
2. **Data Types**: The attributes include integers, floats, and objects (strings). The presence of both numerical and categorical data allows for diverse analyses.
3. **Missing Values**:
- `capital`: 5 missing values (2% of the data)
- `region`: 2 missing values (0.8% of the data)
- `subregion`: 3 missing values (1.2% of the data)
- Other columns have no missing values.
#### Important Features:
1. **id**: Unique identifier for each country. It is uniformly distributed from 1 to 250.
2. **name**: Each country has a unique name, which is crucial for identification.
3. **phone_code**: There are 235 unique phone codes, indicating that some countries share the same code. This could be relevant for understanding regional telecommunications.
4. **capital**: The capital city is a significant attribute, but with 5 missing values, it may require attention during analysis.
5. **currency_name**: There are 161 unique currencies, with the Euro being the most common (35 occurrences). This suggests a potential clustering of countries using the same currency, which could be relevant for economic analyses.
6. **region**: There are 6 unique regions, with Africa having the highest frequency (60 countries). This could indicate a need to explore regional characteristics further.
7. **subregion**: 22 unique subregions exist, with the Caribbean being the most frequent (28 occurrences). This suggests that some regions have more subdivisions than others.
8. **timezones**: The dataset contains 245 unique timezones, indicating that many countries share timezones. This could be useful for understanding global time coordination.
#### Use Case Insights:
1. **Regions and Subregions**: To determine which region contains the most subregions, we can analyze the `region` and `subregion` columns. The region with the highest number of unique subregions will be identified.
2. **Popular Currencies**: The `currency_name` column can be analyzed to find the most frequently occurring currencies, highlighting economic ties between countries.
3. **Shared Timezones**: The `timezones` column can be examined to identify countries that share the same timezone, which may have implications for trade, communication, and travel.
### Conclusion:
The dataset provides a rich source of information about countries, their geographical locations, and economic attributes. The most important features for analysis include `region`, `subregion`, `currency_name`, and `timezones`, as they directly relate to the use cases outlined. Addressing the missing values in `capital`, `region`, and `subregion` will also be essential for a comprehensive analysis.
### Data Modeling
We can now use our Discovery object to provide context to the LLM for data model generation. Notice that we don't need to pass our actual data to the modeler, just insights we've gathered so far.
```Python
gdm = GraphDataModeler(llm=llm_dm, discovery=disc)
```
We may now generate our first graph data model.
```Python
gdm.create_initial_model()
```
If we have graphviz installed, we can take a look at our model.
```Python
gdm.current_model.visualize()
```
![countries-first-model.png](./examples/end_to_end/single_file/countries/images/countries-single-first-model-0.12.0.svg)
Our data model seems to address the three use cases we'd like answered:
* Which region contains the most subregions?
* What currencies are most popular?
* Which countries share timezones?
If we would like the data model modified, we may request the LLM to make changes.
```Python
gdm.iterate_model(corrections="Create a Capital node from the capital property.")
gdm.current_model.visualize()
```
![countries-second-model.png](./examples/end_to_end/single_file/countries/images/countries-single-second-model-0.12.0.svg)
### Code Generation
We can now use our data model to generate some ingestion code.
```Python
gen = PyIngestConfigGenerator(data_model=gdm.current_model,
username=os.environ.get("NEO4J_USERNAME"),
password=os.environ.get("NEO4J_PASSWORD"),
uri=os.environ.get("NEO4J_URI"),
database=os.environ.get("NEO4J_DATABASE"),
file_directory=data_directory, source_name="countries.csv")
pyingest_yaml = gen.generate_config_string()
```
### Ingestion
We will use the generated PyIngest yaml config to ingest our data into our Neo4j instance.
```Python
PyIngest(config=pyingest_yaml, verbose=False)
```
We can also save this as a .yaml file and use with the original [PyIngest](https://github.com/neo4j-field/pyingest).
```Python
gen.generate_config_yaml(file_name="countries.yaml")
```
Here's a snapshot of our new graph!
![countries-graph.png](./examples/end_to_end/single_file/countries/images/countries-single-0.12.0.png)
## Graph Exploratory Data Analysis
Runway offers a module for easily running analyics over an existing graph to gain insights such as finding isolated nodes and ranking top node degrees.
Check [here](./examples/exploratory_data_analysis/stackoverflow/stackoverflow_graph_eda.ipynb) for an example of Runway's `GraphEDA` module.
## Limitations
Runway is currently in beta and under rapid development. Please raise GitHub issues and provide feedback on any features you'd like. The following are some of the current limitations:
- More complex data modeling is under development
- Nodes may only have a single label
- Only uniqueness and key constraints are supported
- Only OpenAI models may be used at this time
- Runway only supports ingesting local files, though it supports code generation for other ingest methods
Raw data
{
"_id": null,
"home_page": null,
"name": "neo4j-runway",
"maintainer": null,
"docs_url": null,
"requires_python": "<4.0,>=3.10",
"maintainer_email": null,
"keywords": "graph, neo4j, data model",
"author": "Alex Gilmore",
"author_email": null,
"download_url": "https://files.pythonhosted.org/packages/d0/f3/573094e4ff013d41f2208ede37c838ef9411f9213badc6fa45628deb6aa2/neo4j_runway-0.14.0.tar.gz",
"platform": null,
"description": "# Neo4j Runway\nNeo4j Runway is a Python library that simplifies the process of migrating your relational data into a graph. It provides tools that abstract communication with OpenAI to run discovery on your data and generate a data model, as well as tools to generate ingestion code and load your data into a Neo4j instance.\n\n<img src=\"./docs/assets/images/neo4j-runway-logo.webp\" width=300 height=400>\n\n\n\n## Key Features\n\n- **Data Discovery**: Harness OpenAI LLMs to provide valuable insights from your data\n- **Graph Data Modeling**: Utilize OpenAI and the [Instructor](https://github.com/jxnl/instructor) Python library to create valid graph data models\n- **Code Generation**: Generate ingestion code to easily load your data\n- **Data Ingestion**: Load your data using Runway's built in implementation of [PyIngest](https://github.com/neo4j-field/pyingest) - Neo4j's popular ingestion tool\n- **Exploratory Data Analysis**: Run analytics over your graph to discover potential data quality issues\n\n## Requirements\nRunway uses Graphviz to visualize data models. To enjoy this feature please download [graphviz](https://www.graphviz.org/download/).\n\nYou'll need a Neo4j instance to fully utilize Runway. Start up a free cloud hosted [Aura](https://console.neo4j.io) instance or download the [Neo4j Desktop app](https://neo4j.com/download/).\n\n## Get Running in Minutes\n\nFollow the steps below or check out any of the Neo4j Runway [end-to-end examples](https://github.com/a-s-g93/neo4j-runway/tree/main/examples/end_to_end)\n\n```\npip install neo4j-runway\n```\n\nNow let's walk through a basic example.\n\nHere we import the modules we'll be using.\n```Python\nfrom neo4j_runway import Discovery, GraphDataModeler, PyIngest, UserInput\nfrom neo4j_runway.code_generation import PyIngestConfigGenerator\nfrom neo4j_runway.llm.openai import OpenAIDiscoveryLLM, OpenAIDataModelingLLM\n\n```\n### Discovery\nNow we...\n- Define a general description of our data\n- Provide brief descriptions of the columns of interest\n- Provide any use cases we'd like our data model to address\n- Load our csv via Runway's `load_local_files` function\n\n```Python\ndata_directory = \"../../../data/countries/\"\n\ndata_dictionary = {\n 'id': 'unique id for a country.',\n 'name': 'the country name.',\n 'phone_code': 'country area code.',\n 'capital': 'the capital of the country.',\n 'currency_name': \"name of the country's currency.\",\n 'region': 'primary region of the country.',\n 'subregion': 'subregion location of the country.',\n 'timezones': 'timezones contained within the country borders.',\n 'latitude': 'the latitude coordinate of the country center.',\n 'longitude': 'the longitude coordinate of the country center.'\n }\n\nuse_cases = [\n \"Which region contains the most subregions?\",\n \"What currencies are most popular?\",\n \"Which countries share timezones?\"\n ]\n\ndata = load_local_files(data_directory=data_directory,\n data_dictionary=data_dictionary,\n general_description=\"This is data on countries and their attributes.\",\n use_cases=use_cases,\n include_files=[\"countries.csv\"])\n```\n\nWe may also preview our csv data before running any processes\n\n```python\ndata.tables[0].dataframe.head()\n```\n\n<div>\n\n<table border=\"1\" class=\"dataframe\">\n <thead>\n <tr style=\"text-align: right;\">\n <th></th>\n <th>id</th>\n <th>name</th>\n <th>phone_code</th>\n <th>capital</th>\n <th>currency_name</th>\n <th>region</th>\n <th>subregion</th>\n <th>timezones</th>\n <th>latitude</th>\n <th>longitude</th>\n </tr>\n </thead>\n <tbody>\n <tr>\n <th>0</th>\n <td>1</td>\n <td>Afghanistan</td>\n <td>93</td>\n <td>Kabul</td>\n <td>Afghan afghani</td>\n <td>Asia</td>\n <td>Southern Asia</td>\n <td>[{zoneName:'Asia\\/Kabul',gmtOffset:16200,gmtOf...</td>\n <td>33.000000</td>\n <td>65.0</td>\n </tr>\n <tr>\n <th>1</th>\n <td>2</td>\n <td>Aland Islands</td>\n <td>+358-18</td>\n <td>Mariehamn</td>\n <td>Euro</td>\n <td>Europe</td>\n <td>Northern Europe</td>\n <td>[{zoneName:'Europe\\/Mariehamn',gmtOffset:7200,...</td>\n <td>60.116667</td>\n <td>19.9</td>\n </tr>\n <tr>\n <th>2</th>\n <td>3</td>\n <td>Albania</td>\n <td>355</td>\n <td>Tirana</td>\n <td>Albanian lek</td>\n <td>Europe</td>\n <td>Southern Europe</td>\n <td>[{zoneName:'Europe\\/Tirane',gmtOffset:3600,gmt...</td>\n <td>41.000000</td>\n <td>20.0</td>\n </tr>\n <tr>\n <th>3</th>\n <td>4</td>\n <td>Algeria</td>\n <td>213</td>\n <td>Algiers</td>\n <td>Algerian dinar</td>\n <td>Africa</td>\n <td>Northern Africa</td>\n <td>[{zoneName:'Africa\\/Algiers',gmtOffset:3600,gm...</td>\n <td>28.000000</td>\n <td>3.0</td>\n </tr>\n <tr>\n <th>4</th>\n <td>5</td>\n <td>American Samoa</td>\n <td>+1-684</td>\n <td>Pago Pago</td>\n <td>US Dollar</td>\n <td>Oceania</td>\n <td>Polynesia</td>\n <td>[{zoneName:'Pacific\\/Pago_Pago',gmtOffset:-396...</td>\n <td>-14.333333</td>\n <td>-170.0</td>\n </tr>\n </tbody>\n</table>\n</div>\n\n\nWe may then initialize our discovery and data modeling LLMs. By default we use GPT-4o and define our OpenAI API key in an environment variable.\n\n```Python\nllm_disc = OpenAIDiscoveryLLM(model_name='gpt-4o-mini-2024-07-18', model_params={\"temperature\": 0})\nllm_dm = OpenAIDataModelingLLM(model_name='gpt-4o-2024-05-13', model_params={\"temperature\": 0.5})\n```\n\nAnd we run discovery on our data.\n```Python\ndisc = Discovery(llm=llm_disc, data=data)disc.run()\n\ndisc.run(show_result=True, notebook=True)\n```\n### Preliminary Analysis of Country Data\n\n#### Overall Data Characteristics:\n1. **Data Size**: The dataset contains 250 entries (countries) and 10 attributes.\n2. **Data Types**: The attributes include integers, floats, and objects (strings). The presence of both numerical and categorical data allows for diverse analyses.\n3. **Missing Values**:\n - `capital`: 5 missing values (2% of the data)\n - `region`: 2 missing values (0.8% of the data)\n - `subregion`: 3 missing values (1.2% of the data)\n - Other columns have no missing values.\n\n#### Important Features:\n1. **id**: Unique identifier for each country. It is uniformly distributed from 1 to 250.\n2. **name**: Each country has a unique name, which is crucial for identification.\n3. **phone_code**: There are 235 unique phone codes, indicating that some countries share the same code. This could be relevant for understanding regional telecommunications.\n4. **capital**: The capital city is a significant attribute, but with 5 missing values, it may require attention during analysis.\n5. **currency_name**: There are 161 unique currencies, with the Euro being the most common (35 occurrences). This suggests a potential clustering of countries using the same currency, which could be relevant for economic analyses.\n6. **region**: There are 6 unique regions, with Africa having the highest frequency (60 countries). This could indicate a need to explore regional characteristics further.\n7. **subregion**: 22 unique subregions exist, with the Caribbean being the most frequent (28 occurrences). This suggests that some regions have more subdivisions than others.\n8. **timezones**: The dataset contains 245 unique timezones, indicating that many countries share timezones. This could be useful for understanding global time coordination.\n\n#### Use Case Insights:\n1. **Regions and Subregions**: To determine which region contains the most subregions, we can analyze the `region` and `subregion` columns. The region with the highest number of unique subregions will be identified.\n2. **Popular Currencies**: The `currency_name` column can be analyzed to find the most frequently occurring currencies, highlighting economic ties between countries.\n3. **Shared Timezones**: The `timezones` column can be examined to identify countries that share the same timezone, which may have implications for trade, communication, and travel.\n\n### Conclusion:\nThe dataset provides a rich source of information about countries, their geographical locations, and economic attributes. The most important features for analysis include `region`, `subregion`, `currency_name`, and `timezones`, as they directly relate to the use cases outlined. Addressing the missing values in `capital`, `region`, and `subregion` will also be essential for a comprehensive analysis.\n\n\n\n### Data Modeling\nWe can now use our Discovery object to provide context to the LLM for data model generation. Notice that we don't need to pass our actual data to the modeler, just insights we've gathered so far.\n\n```Python\ngdm = GraphDataModeler(llm=llm_dm, discovery=disc)\n```\n\nWe may now generate our first graph data model.\n\n```Python\ngdm.create_initial_model()\n```\n\nIf we have graphviz installed, we can take a look at our model.\n\n```Python\ngdm.current_model.visualize()\n```\n![countries-first-model.png](./examples/end_to_end/single_file/countries/images/countries-single-first-model-0.12.0.svg)\n\nOur data model seems to address the three use cases we'd like answered:\n* Which region contains the most subregions?\n* What currencies are most popular?\n* Which countries share timezones?\n\nIf we would like the data model modified, we may request the LLM to make changes.\n\n```Python\ngdm.iterate_model(corrections=\"Create a Capital node from the capital property.\")\ngdm.current_model.visualize()\n```\n![countries-second-model.png](./examples/end_to_end/single_file/countries/images/countries-single-second-model-0.12.0.svg)\n\n### Code Generation\nWe can now use our data model to generate some ingestion code.\n\n```Python\ngen = PyIngestConfigGenerator(data_model=gdm.current_model,\n username=os.environ.get(\"NEO4J_USERNAME\"),\n password=os.environ.get(\"NEO4J_PASSWORD\"),\n uri=os.environ.get(\"NEO4J_URI\"),\n database=os.environ.get(\"NEO4J_DATABASE\"),\n file_directory=data_directory, source_name=\"countries.csv\")\n\npyingest_yaml = gen.generate_config_string()\n\n```\n### Ingestion\nWe will use the generated PyIngest yaml config to ingest our data into our Neo4j instance.\n\n```Python\nPyIngest(config=pyingest_yaml, verbose=False)\n```\n\nWe can also save this as a .yaml file and use with the original [PyIngest](https://github.com/neo4j-field/pyingest).\n\n```Python\ngen.generate_config_yaml(file_name=\"countries.yaml\")\n```\n\nHere's a snapshot of our new graph!\n\n![countries-graph.png](./examples/end_to_end/single_file/countries/images/countries-single-0.12.0.png)\n\n\n## Graph Exploratory Data Analysis\n\nRunway offers a module for easily running analyics over an existing graph to gain insights such as finding isolated nodes and ranking top node degrees.\n\nCheck [here](./examples/exploratory_data_analysis/stackoverflow/stackoverflow_graph_eda.ipynb) for an example of Runway's `GraphEDA` module.\n\n\n## Limitations\nRunway is currently in beta and under rapid development. Please raise GitHub issues and provide feedback on any features you'd like. The following are some of the current limitations:\n- More complex data modeling is under development\n- Nodes may only have a single label\n- Only uniqueness and key constraints are supported\n- Only OpenAI models may be used at this time\n- Runway only supports ingesting local files, though it supports code generation for other ingest methods\n",
"bugtrack_url": null,
"license": "Apache License, Version 2.0",
"summary": "A Python library that contains tools for data discovery, data model generation and ingestion for the Neo4j graph database.",
"version": "0.14.0",
"project_urls": null,
"split_keywords": [
"graph",
" neo4j",
" data model"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "f25dcd5842ddfc0e22bab387f81d13034447ec9d3b3334f3961452e729c319f4",
"md5": "281e77f242d8acc5c6cc2b5f75598bb6",
"sha256": "75c18fe230902fff93bc8bf2890d7783c5d49f7a28dc53ac83e4077da30aee0c"
},
"downloads": -1,
"filename": "neo4j_runway-0.14.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "281e77f242d8acc5c6cc2b5f75598bb6",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<4.0,>=3.10",
"size": 100673,
"upload_time": "2024-11-04T14:01:18",
"upload_time_iso_8601": "2024-11-04T14:01:18.328611Z",
"url": "https://files.pythonhosted.org/packages/f2/5d/cd5842ddfc0e22bab387f81d13034447ec9d3b3334f3961452e729c319f4/neo4j_runway-0.14.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "d0f3573094e4ff013d41f2208ede37c838ef9411f9213badc6fa45628deb6aa2",
"md5": "d72b42f6457ba75bc6317f6688a12315",
"sha256": "cc199a349808f248bcb8addd7fd3f20ca5b51bcd1a35d6b9481c10bcb454fd08"
},
"downloads": -1,
"filename": "neo4j_runway-0.14.0.tar.gz",
"has_sig": false,
"md5_digest": "d72b42f6457ba75bc6317f6688a12315",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<4.0,>=3.10",
"size": 72355,
"upload_time": "2024-11-04T14:01:19",
"upload_time_iso_8601": "2024-11-04T14:01:19.733421Z",
"url": "https://files.pythonhosted.org/packages/d0/f3/573094e4ff013d41f2208ede37c838ef9411f9213badc6fa45628deb6aa2/neo4j_runway-0.14.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-11-04 14:01:19",
"github": false,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"lcname": "neo4j-runway"
}