[](https://github.com/Arzenon/aioredisgraph-py)
[](https://circleci.com/gh/RedisGraph/redisgraph-py/tree/master)
[](https://badge.fury.io/py/redisgraph)
[](https://github.com/RedisGraph/redisgraph-py/releases/latest)
[](https://codecov.io/gh/RedisGraph/redisgraph-py)
[](https://snyk.io/test/github/RedisGraph/redisgraph-py?targetFile=pyproject.toml)
[](https://lgtm.com/projects/g/RedisGraph/redisgraph-py/alerts/)
# aioredisgraph-py
[](https://forum.redis.com/c/modules/redisgraph)
[](https://discord.gg/gWBRT6P)
Asynchronous fork of [RedisGraph python client](https://github.com/RedisGraph/redisgraph-py/)
## Example: Using the Python Client
```python
import asyncio
from aioredisgraph import Node, Edge, Graph, Path
async def main():
url = 'redis://localhost:6379'
redis_graph = Graph('social', url)
john = Node(label='person', properties={'name': 'John Doe', 'age': 33, 'gender': 'male', 'status': 'single'})
redis_graph.add_node(john)
japan = Node(label='country', properties={'name': 'Japan'})
redis_graph.add_node(japan)
edge = Edge(john, 'visited', japan, properties={'purpose': 'pleasure'})
redis_graph.add_edge(edge)
await redis_graph.commit()
query = """MATCH (p:person)-[v:visited {purpose:"pleasure"}]->(c:country)
RETURN p.name, p.age, v.purpose, c.name"""
result = await redis_graph.query(query)
# Print resultset
result.pretty_print()
# Use parameters
params = {'purpose': "pleasure"}
query = """MATCH (p:person)-[v:visited {purpose:$purpose}]->(c:country)
RETURN p.name, p.age, v.purpose, c.name"""
result = await redis_graph.query(query, params)
# Print resultset
result.pretty_print()
# Use query timeout to raise an exception if the query takes over 10 milliseconds
result = await redis_graph.query(query, params, timeout=10)
# Iterate through resultset
for record in result.result_set:
person_name = record[0]
person_age = record[1]
visit_purpose = record[2]
country_name = record[3]
query = """MATCH p = (:person)-[:visited {purpose:"pleasure"}]->(:country) RETURN p"""
result = await redis_graph.query(query)
# Iterate through resultset
for record in result.result_set:
path = record[0]
print(path)
# All done, remove graph.
await redis_graph.delete()
if __name__ == '__main__':
asyncio.run(main())
```
## Installing
### Install official release
```
pip install aioredisgraph
```
### Install latest release (Aligned with AioRedisGraph master)
```
pip install git+https://github.com/Arzenon/aioredisgraph-py.git@master
```
### Install for development in env
1. Create a virtualenv to manage your python dependencies, and ensure it's active.
```virtualenv -v venv; source venv/bin/activate```
2. Install [pypoetry](https://python-poetry.org/) to manage your dependencies.
```pip install poetry```
3. Install dependencies.
```poetry install```
[tox](https://tox.readthedocs.io/en/latest/) runs all code linters as its default target.