A package for Neo4j data ingestion using an AI agent.
Project description
neo-pusher
neo-pusher
is a Python package designed to facilitate the seamless transfer of data from CSV files to a Neo4j database. Leveraging the power of OpenAI's GPT models and the LangChain framework, neo-pusher
automates the process of schema generation, data preprocessing, and data insertion into Neo4j, ensuring data consistency and integrity.
Features
- Automated Schema Generation: Automatically generates a Neo4j schema based on the CSV file's headers.
- Data Preprocessing: Identifies and resolves inconsistencies in the data before pushing it to Neo4j.
- Error Handling and Debugging: The agent reruns and debugs code automatically if any errors are encountered during the process.
- Multiple Dataset Support: Capable of handling multiple datasets simultaneously, ensuring that all columns are properly represented in the database.
Usage
Here's an example of how to use neo-pusher
to push data from a CSV file to a Neo4j database:
from neo_pusher.agent import NeoAgent
# Initialize the NeoAgent with your OpenAI API key
agent = NeoAgent(apikey="your_openai_api_key",lang_chain_api_key="your_lang_chain_api_key")
# Define the parameters for your Neo4j database and CSV file
path = "path/to/your/csvfile.csv"
username = "neo4j_username"
password = "neo4j_password"
url = "bolt://localhost:7687"
data = "head of your csv data"
# Run the agent to push data to Neo4j
response = agent.run(path, username, password, url, data)
print(response)
Parameters
apikey
(str): Your OpenAI API key.langchain_api_key
(str): Your Langchain API key.model
(str): The OpenAI model to use. Defaults to"gpt-4o"
.path
(str): The path to the CSV file.username
(str): The username for the Neo4j database.password
(str): The password for the Neo4j database.url
(str): The URL of the Neo4j database.data
(str): The head of the CSV file. Defaults toNone
.
Return Value
- The
run
method returns a response from the LLM, including the results of the schema generation, data preprocessing, and data insertion into Neo4j.
Example CSV Data
The following is an example of the CSV file headers that neo-pusher
can process:
Dataset 1:
order_details_id | order_id | pizza_id | quantity |
---|---|---|---|
1 | 1 | hawaiian_m | 1 |
2 | 2 | classic_dlx_m | 1 |
Dataset 2:
pizza_id | pizza_type_id | size | price |
---|---|---|---|
bbq_ckn_s | bbq_ckn | S | 12.75 |
bbq_ckn_m | bbq_ckn | M | 16.75 |
Notes
- The agent uses the
neo4j
Python package to connect to and push data into the Neo4j database. - Before pushing data, the agent checks for any inconsistencies and cleans the data accordingly.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file neo_pusher-1.1.0.tar.gz
.
File metadata
- Download URL: neo_pusher-1.1.0.tar.gz
- Upload date:
- Size: 14.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2c5392f1aac4309d5c22efb84d50ad6955cfd06b1151ce8c92761642389b7410 |
|
MD5 | e2b3ae2459e0c85ad07bb3c285d5ec3d |
|
BLAKE2b-256 | 547c7a4cd347a8bd23a16e7459e7807b31cc625c4a9d5c32b40ed418dcb2f7a8 |
File details
Details for the file neo_pusher-1.1.0-py3-none-any.whl
.
File metadata
- Download URL: neo_pusher-1.1.0-py3-none-any.whl
- Upload date:
- Size: 6.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6a8e5d97c188d798fdcf3872ec530d5e61c4920ecde80a3e58ac551f782fb7b9 |
|
MD5 | c2b3a0f3f7f033a26850cf2f32144a1f |
|
BLAKE2b-256 | bb61e50903b2fcb6fb6a1cda8cdef1f112945ec6adc72dae2f61e177c8b5a4a6 |