当前位置: 首页 > article >正文

neo4j随笔-将csv文件导入知识图谱

目录

导入前的准备

导入csv文件

导入nodes1.1.csv并动态为节点添加标签

​编辑导入relations1.1.csv并动态为关系添加标签

结果


导入前的准备

我有两个csv文件

nodes1.1.csv存放节点信息,用记事本打开,能正常显示,且编码为UTF-8,就可以使用。虽然在excel表打开是乱码

relations1.1.csv存放节点信息,用记事本打开,能正常显示,且编码为UTF-8,就可以使用。虽然在excel表打开是乱码

然后将这两个csv文件放到neo4j的import目录下(linux的neo4j在/var/lib/neo4j/import)

因为我们还要通过节点信息动态生成节点标签,也要通过关系信息动态生成关系标签,所以需要安装apoc插件。

可以看这位博主的博客:2025最新Neo4j安装apoc插件-CSDN博客

导入csv文件

插件安装完毕后,就可以打开网页版neo4j

执行Cypher语句

导入nodes1.1.csv并动态为节点添加标签

LOAD CSV WITH HEADERS FROM 'file:///nodes1.1.csv' AS row
MERGE (n:Node {id: row.id})
SET n.name = row.name, 
    n.type = row.type, 
    n.description = row.description, 
    n.expression = row.expression
WITH n, row
CALL apoc.create.addLabels(n, [row.type]) YIELD node  // 动态为节点添加标签
RETURN node;


导入relations1.1.csv并动态为关系添加标签

LOAD CSV WITH HEADERS FROM 'file:///relations1.1.csv' AS row
MATCH (source:Node {id: row.source_id})
MATCH (target:Node {id: row.target_id})
CALL apoc.merge.relationship(source, row.relation, {}, {}, target) YIELD rel
RETURN rel;

结果

顺利导入


http://www.kler.cn/a/578928.html

相关文章:

  • 【Java代码审计 | 第八篇】文件操作漏洞成因及防范
  • IntelliJ IDEA 2021版创建springboot项目的五种方式
  • javaEE初阶————多线程进阶(1)
  • 大整数加法(信息学奥赛一本通-1168)
  • NoSQL数据库系统Cassandra学习笔记
  • Prompt engineering设计原则
  • 力扣HOT100之哈希:128. 最长连续序列
  • 学习LED驱动知识(二)
  • 神经网络中梯度计算求和公式求导问题
  • 【MySQL】索引(页目录、B+树)
  • Go学习笔记:go 操作mysql和Redis
  • OkHttp:工作原理 拦截器链深度解析
  • Git基础之基础概念
  • 消息队列MQ(RabbitMQ)
  • 2025-3-9哈弗曼树
  • OPENGLPG第九版学习 -颜色、像素和片元 PART1
  • python flask
  • 跨越时空的对话:图灵与GPT-4聊AI的前世今生
  • 在MATLAB环境中,对矩阵拼接(Matrix Concatenation)的测试
  • 【 <一> 炼丹初探:JavaWeb 的起源与基础】之 JSP 中的内置对象:request、response、session 的使用示例