Neo4j Python 驱动库完整教程(带输入输出示例)

Neo4j Python 驱动库完整教程(带输入输出示例)

1. 基础连接示例

输入代码

python 复制代码
from neo4j import GraphDatabase

# 连接配置
URI = "bolt://localhost:7687"
USER = "neo4j"
PASSWORD = "password123"  # 替换为你的实际密码

def test_connection():
    driver = GraphDatabase.driver(URI, auth=(USER, PASSWORD))
    try:
        driver.verify_connectivity()
        server_info = driver.get_server_info()
        print("连接信息:")
        print(f"地址: {URI}")
        print(f"版本: {server_info.agent}")
    except Exception as e:
        print(f"连接失败: {e}")
    finally:
        driver.close()

test_connection()

示例输出

复制代码
连接信息:
地址: bolt://localhost:7687
版本: Neo4j/5.13.0

2. 基本CRUD操作

输入代码

python 复制代码
class Neo4jCRUD:
    def __init__(self, uri, user, password):
        self.driver = GraphDatabase.driver(uri, auth=(user, password))

    def create_person(self, name, age):
        with self.driver.session() as session:
            result = session.execute_write(
                self._create_person, name, age
            )
            return result

    @staticmethod
    def _create_person(tx, name, age):
        query = (
            "CREATE (p:Person {name: $name, age: $age}) "
            "RETURN p.name AS name, p.age AS age"
        )
        result = tx.run(query, name=name, age=age)
        return result.single()

# 使用示例
crud = Neo4jCRUD(URI, USER, PASSWORD)
print("创建节点:")
result = crud.create_person("Alice", 30)
print(result)
crud.close()

示例输出

复制代码
创建节点:
{'name': 'Alice', 'age': 30}

3. 查询操作

输入代码

python 复制代码
def find_person(name):
    driver = GraphDatabase.driver(URI, auth=(USER, PASSWORD))
    with driver.session() as session:
        result = session.execute_read(
            lambda tx: tx.run(
                "MATCH (p:Person {name: $name}) RETURN p",
                name=name
            ).single()
        )
        return dict(result["p"]) if result else None

print("\n查询结果:")
alice = find_person("Alice")
print(alice)

示例输出

复制代码
查询结果:
{'name': 'Alice', 'age': 30}

4. 关系创建

输入代码

python 复制代码
def create_movie_and_relationship():
    driver = GraphDatabase.driver(URI, auth=(USER, PASSWORD))
    with driver.session() as session:
        # 创建电影节点
        movie = session.execute_write(
            lambda tx: tx.run(
                "CREATE (m:Movie {title: $title, year: $year}) RETURN m",
                title="The Matrix", year=1999
            ).single()
        )
        
        # 创建关系
        relationship = session.execute_write(
            lambda tx: tx.run(
                """MATCH (p:Person {name: $name}), (m:Movie {title: $title})
                CREATE (p)-[r:ACTED_IN {role: $role}]->(m)
                RETURN p.name, type(r), m.title""",
                name="Alice", title="The Matrix", role="Neo"
            ).single()
        )
        return relationship

print("\n创建关系结果:")
rel_result = create_movie_and_relationship()
print(rel_result)

示例输出

复制代码
创建关系结果:
{'p.name': 'Alice', 'type(r)': 'ACTED_IN', 'm.title': 'The Matrix'}

5. 复杂查询

输入代码

python 复制代码
def find_actors_in_movie(movie_title):
    driver = GraphDatabase.driver(URI, auth=(USER, PASSWORD))
    with driver.session() as session:
        result = session.execute_read(
            lambda tx: tx.run(
                """MATCH (p:Person)-[r:ACTED_IN]->(m:Movie)
                WHERE m.title = $title
                RETURN p.name AS actor, r.role AS role""",
                title=movie_title
            ).data()
        )
        return result

print("\n电影演员查询:")
actors = find_actors_in_movie("The Matrix")
for actor in actors:
    print(f"{actor['actor']} 饰演 {actor['role']}")

示例输出

复制代码
电影演员查询:
Alice 饰演 Neo

6. 批量导入示例

输入代码

python 复制代码
def batch_import_people():
    people = [
        {"name": "Bob", "age": 25},
        {"name": "Charlie", "age": 35},
        {"name": "David", "age": 40}
    ]
    
    driver = GraphDatabase.driver(URI, auth=(USER, PASSWORD))
    with driver.session() as session:
        result = session.execute_write(
            lambda tx: tx.run(
                "UNWIND $people AS person "
                "CREATE (p:Person {name: person.name, age: person.age}) "
                "RETURN count(p) AS count",
                people=people
            ).single()
        )
        return result["count"]

print("\n批量导入结果:")
count = batch_import_people()
print(f"成功导入 {count} 个人物节点")

示例输出

复制代码
批量导入结果:
成功导入 3 个人物节点

7. 图形数据可视化示例

输入代码

python 复制代码
def visualize_graph():
    driver = GraphDatabase.driver(URI, auth=(USER, PASSWORD))
    with driver.session() as session:
        # 查询图形结构
        result = session.execute_read(
            lambda tx: tx.run(
                """MATCH (p:Person)-[r]->(m)
                RETURN p, r, m
                LIMIT 10"""
            ).graph()
        )
        
        # 打印图形结构信息
        print("\n图形结构信息:")
        print(f"节点数量: {len(result.nodes)}")
        print(f"关系数量: {len(result.relationships)}")
        
        # 打印前3个节点的详细信息
        print("\n节点示例:")
        for i, node in enumerate(list(result.nodes)[:3], 1):
            print(f"节点 {i}: {dict(node)}")
        
        # 打印关系示例
        print("\n关系示例:")
        for rel in list(result.relationships)[:2]:
            print(f"{rel.start_node['name']} -[{rel.type}]-> {rel.end_node['title']}")

visualize_graph()

示例输出

复制代码
图形结构信息:
节点数量: 5
关系数量: 1

节点示例:
节点 1: {'name': 'Alice', 'age': 30}
节点 2: {'title': 'The Matrix', 'year': 1999}
节点 3: {'name': 'Bob', 'age': 25}

关系示例:
Alice -[ACTED_IN]-> The Matrix

这些示例展示了从基础连接到复杂查询的完整流程,每个示例都包含明确的输入代码和对应的预期输出结果。

相关推荐
共享家952715 小时前
搭建 AI 聊天机器人:”我的人生我做主“
前端·javascript·css·python·pycharm·html·状态模式
疯狂的喵15 小时前
C++编译期多态实现
开发语言·c++·算法
2301_7657031415 小时前
C++中的协程编程
开发语言·c++·算法
m0_7487080515 小时前
实时数据压缩库
开发语言·c++·算法
Hgfdsaqwr15 小时前
Python在2024年的主要趋势与发展方向
jvm·数据库·python
lly20240616 小时前
jQuery Mobile 表格
开发语言
一晌小贪欢16 小时前
Python 测试利器:使用 pytest 高效编写和管理单元测试
python·单元测试·pytest·python3·python测试
小文数模16 小时前
2026年美赛数学建模C题完整参考论文(含模型和代码)
python·数学建模·matlab
惊讶的猫16 小时前
探究StringBuilder和StringBuffer的线程安全问题
java·开发语言
Halo_tjn16 小时前
基于封装的专项 知识点
java·前端·python·算法