从 Neo4j 数据库中提取数据并绘制图谱


代码说明:

  1. 连接 Neo4j 数据库

    • 使用 py2neo.Graph 连接到 Neo4j 数据库。
    • 确保替换 uriusernamepassword 为你的实际配置。
  2. Cypher 查询

    • 查询数据库中的节点和关系,限制返回的记录数(例如 LIMIT 100)以避免性能问题。
  3. NetworkX 图对象

    • 使用 networkx.MultiDiGraph 创建一个有向图对象。
    • 将查询结果中的节点和关系添加到图中。
  4. 绘制图形

    • 使用 matplotlibnetworkx 的绘图功能,将图谱可视化。
    • 节点和边的标签可以根据需要调整。
bash 复制代码
from py2neo import Graph
import networkx as nx
import matplotlib.pyplot as plt

# 1. 连接到 Neo4j 数据库
uri = "bolt://localhost:7687"  # 替换为你的 Neo4j URI
username = "neo4j"             # 替换为你的用户名
password = "password"          # 替换为你的密码

graph = Graph(uri, auth=(username, password))

# 2. 使用 Cypher 查询获取节点和关系
query = """
MATCH (n)-[r]->(m)
RETURN n, r, m
LIMIT 100
"""
results = graph.run(query)

# 3. 创建 NetworkX 图对象
G = nx.MultiDiGraph()

# 4. 将查询结果添加到 NetworkX 图中
for record in results:
    source = record["n"]
    target = record["m"]
    relation = record["r"]

    # 添加节点(如果节点已经有标签或属性,可以提取出来)
    G.add_node(source.identity, label=source['name'] if 'name' in source else "")
    G.add_node(target.identity, label=target['name'] if 'name' in target else "")

    # 添加边(关系)
    G.add_edge(source.identity, target.identity, label=relation.type)

# 5. 绘制图形
plt.figure(figsize=(12, 8))

# 设置布局
pos = nx.spring_layout(G, seed=42)

# 绘制节点
nx.draw_networkx_nodes(G, pos, node_size=300, node_color="lightblue")

# 绘制边
nx.draw_networkx_edges(G, pos, arrows=True)

# 绘制节点标签
node_labels = {node_id: G.nodes[node_id].get("label", "") for node_id in G.nodes()}
nx.draw_networkx_labels(G, pos, labels=node_labels, font_size=10)

# 绘制边标签
edge_labels = {(u, v): G[u][v][0]['label'] for u, v in G.edges()}
nx.draw_networkx_edge_labels(G, pos, edge_labels=edge_labels, font_size=8)

# 显示图形
plt.title("Neo4j 图谱可视化")
plt.axis("off")  # 关闭坐标轴
plt.show()

输出示例:

运行上述代码后,你将看到一个可视化的图谱,其中:

  • 节点表示 Neo4j 中的实体。
  • 边表示实体之间的关系。
  • 节点和边的标签显示了它们的名称或类型。
相关推荐
廿一夏5 小时前
MySql存储引擎与索引
数据库·sql·mysql
lzhdim6 小时前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
瀚高PG实验室7 小时前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
TDengine (老段)7 小时前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
YOU OU8 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng9 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
罗超驿10 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
jran-10 小时前
Redis 命令
数据库·redis·缓存
小江的记录本10 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
June`11 小时前
多线程redis下如何解决aof重写和rdb持久化的数据一致性问题
数据库·redis·缓存