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

知识图谱入门第一步:用SpringBoot+HanLP快速构建你的中文实体识别与关系抽取Demo

知识图谱实战基于SpringBoot与HanLP的中文实体关系抽取系统构建指南在人工智能与大数据技术蓬勃发展的今天知识图谱作为结构化知识的重要载体正在智能搜索、推荐系统、金融风控等领域展现出巨大价值。但对于许多刚接触这一领域的开发者而言如何从零开始构建一个能够处理中文文本的知识图谱系统往往面临着技术选型复杂、工具链陌生等挑战。本文将带您使用SpringBoot框架与HanLP自然语言处理工具快速搭建一个具备中文实体识别与关系抽取能力的知识图谱基础系统。不同于简单的API调用演示我们将聚焦于实际应用场景通过一个完整的新闻文本分析案例展示从原始文本到知识网络的全流程实现。1. 环境准备与HanLP集成1.1 项目初始化与依赖配置首先创建一个基础的SpringBoot项目推荐使用Spring Initializrhttps://start.spring.io/生成项目骨架。在pom.xml中添加HanLP依赖dependency groupIdcom.hankcs/groupId artifactIdhanlp/artifactId versionportable-1.8.4/version /dependency与常规Java库不同HanLP采用数据与程序分离的架构。我们需要下载数据包并配置访问路径从HanLP官方GitHub仓库https://github.com/hankcs/HanLP下载data-for-1.8.4.zip解压到项目目录下的/data文件夹创建src/main/resources/hanlp.properties配置文件root./data提示国内用户可从HanLP官网获取百度网盘下载链接避免GitHub下载速度过慢的问题。1.2 基础功能验证编写一个简单的测试Controller验证集成是否成功RestController RequestMapping(/nlp) public class NlpDemoController { GetMapping(/segment) public ListTerm segment(RequestParam String text) { return HanLP.segment(text); } }启动应用后访问http://localhost:8080/nlp/segment?text中国科学院计算技术研究所应得到类似以下输出[ {word:中国科学院,nature:nt}, {word:计算技术,nature:n}, {word:研究所,nature:n} ]2. 中文实体识别实战2.1 命名实体识别(NER)基础HanLP提供了多种命名实体识别模型我们可以通过NER类进行调用。以下是一个识别新闻文本中实体的示例public ListListTerm recognizeEntities(String content) { ListListTerm sentenceList NLPTokenizer.segment2sentence(content); return sentenceList.stream() .map(sentence - { ListTerm terms new ArrayList(); for (Term term : sentence) { if (!term.nature.toString().startsWith(w)) { // 过滤标点 terms.add(term); } } return terms; }) .collect(Collectors.toList()); }对于输入文本阿里巴巴创始人马云在杭州宣布成立达摩院该方法将识别出组织名阿里巴巴、达摩院人名马云地名杭州2.2 实体类型扩展与自定义词典HanLP默认支持以下实体类型实体类型标签示例人名nr张三地名ns北京机构名nt腾讯公司时间t2023年可以通过自定义词典扩展识别范围。在data/dictionary/custom目录下创建custom.txt元宇宙 nz 1000 区块链 nz 1000修改配置启用自定义词典CustomDictionaryPathdata/dictionary/custom/custom.txt3. 关系抽取与知识图谱构建3.1 基于依存句法分析的关系发现HanLP的依存句法分析功能可以帮助我们发现实体间的关系。以下代码展示如何分析句子结构public ListCoNLLSentence extractRelations(String text) { return HanLP.parseDependency(text).stream() .filter(sentence - { // 过滤不含实体的句子 return sentence.getWordArray().length 3; }) .collect(Collectors.toList()); }对于句子马云创立阿里巴巴分析结果将包含创立(马云, 阿里巴巴)3.2 知识图谱数据结构设计定义简单的知识图谱节点与关系结构Data public class KnowledgeGraph { private SetEntity entities; private SetRelation relations; Data public static class Entity { private String id; private String name; private String type; } Data public static class Relation { private String sourceId; private String targetId; private String type; } }3.3 完整处理流程实现整合实体识别与关系抽取的完整服务Service public class KnowledgeGraphService { public KnowledgeGraph buildFromText(String text) { KnowledgeGraph graph new KnowledgeGraph(); // 实体识别 ListListTerm sentences recognizeEntities(text); // 关系抽取 sentences.forEach(sentence - { String sentenceText sentence.stream() .map(Term::getWord) .collect(Collectors.joining()); CoNLLSentence deps HanLP.parseDependency(sentenceText); // 解析依存关系构建图谱 // ... }); return graph; } }4. 系统优化与生产部署4.1 性能优化策略HanLP在处理长文本时可能遇到性能问题可以采用以下优化方案异步处理将耗时操作放入线程池批量处理积累一定量文本后统一处理缓存机制对重复出现的实体进行缓存Async(nlpExecutor) public CompletableFutureKnowledgeGraph asyncBuildGraph(String text) { return CompletableFuture.completedFuture(buildFromText(text)); }4.2 微服务化部署将系统拆分为独立服务NLP服务专门处理文本分析图谱服务管理知识图谱存储与查询API网关统一接口暴露使用Spring Cloud组件实现服务间通信FeignClient(name nlp-service) public interface NlpServiceClient { PostMapping(/kg/build) KnowledgeGraph buildKnowledgeGraph(RequestBody String text); }4.3 监控与日志添加Prometheus监控指标Bean MeterRegistryCustomizerMeterRegistry metricsCommonTags() { return registry - registry.config().commonTags( application, knowledge-graph-service); }配置日志记录NLP处理过程Aspect Component Slf4j public class NlpLoggingAspect { Around(execution(* com.example..*(String)) args(text)) public Object logNlpProcess(ProceedingJoinPoint joinPoint, String text) { long start System.currentTimeMillis(); try { Object result joinPoint.proceed(); log.info(Processed text in {}ms: {}, System.currentTimeMillis()-start, text.substring(0, Math.min(50, text.length()))); return result; } catch (Throwable e) { log.error(NLP processing failed, e); throw new RuntimeException(e); } } }5. 应用场景扩展5.1 新闻领域知识图谱构建流程示例爬取新闻数据抽取实体与关系存储到图数据库实现智能查询public void processNewsArticle(NewsArticle article) { // 正文分析 KnowledgeGraph graph buildFromText(article.getContent()); // 存储到Neo4j graph.getEntities().forEach(entity - { neo4jTemplate.save(entity); }); graph.getRelations().forEach(relation - { neo4jTemplate.save(relation); }); }5.2 金融风控应用在金融领域可以分析企业关联关系输入文本A公司通过其子公司B控股C企业实际控制人为张某 输出图谱 A公司 → 控股 → B公司 B公司 → 控股 → C企业 张某 → 控制 → A公司实现代码public void analyzeCompanyRelations(String text) { KnowledgeGraph graph buildFromText(text); // 特别处理控股、投资等关系 graph.getRelations().forEach(relation - { if (控股.equals(relation.getType())) { relation.setType(HOLDING); } // 其他关系类型转换... }); riskAnalysisService.evaluate(graph); }5.3 医疗知识图谱处理医疗文本时需要特殊处理public class MedicalEntityRecognizer { private static final SetString MEDICAL_TYPES Set.of(疾病, 症状, 药品, 检查); public ListEntity recognizeMedicalEntities(String text) { return HanLP.segment(text).stream() .filter(term - MEDICAL_TYPES.contains(term.getNature())) .map(term - new Entity(term.getWord(), term.getNature())) .collect(Collectors.toList()); } }在实际项目中我们发现HanLP的默认模型对专业领域实体识别效果有限这时可以采用领域自适应技术收集领域文本如医学论文标注典型实体训练领域特定模型集成到现有系统public void trainDomainModel(ListLabeledSentence trainingData) { LinearModel model new CRFLexicalAnalyzer() .train(trainingData) .getModel(); HanLP.Config.CustomDictionaryPath data/medical/dict.txt; HanLP.Config.CoreDictionaryPath data/medical/core.txt; HanLP.Config.BiGramDictionaryPath data/medical/bigram.txt; }

相关文章:

知识图谱入门第一步:用SpringBoot+HanLP快速构建你的中文实体识别与关系抽取Demo

知识图谱实战:基于SpringBoot与HanLP的中文实体关系抽取系统构建指南 在人工智能与大数据技术蓬勃发展的今天,知识图谱作为结构化知识的重要载体,正在智能搜索、推荐系统、金融风控等领域展现出巨大价值。但对于许多刚接触这一领域的开发者而…...

NRF52832实战指南:串口DFU固件升级全流程解析

1. NRF52832串口DFU升级核心概念解析 第一次接触NRF52832的串口DFU功能时,我被各种专业术语搞得晕头转向。经过实际项目验证后,我发现理解这几个核心概念就能掌握80%的关键点: Bootloader就像设备的"开机自检程序",它负…...

如何在PC上完美运行PS3游戏:RPCS3模拟器终极指南

如何在PC上完美运行PS3游戏:RPCS3模拟器终极指南 【免费下载链接】rpcs3 PS3 emulator/debugger 项目地址: https://gitcode.com/GitHub_Trending/rp/rpcs3 你是否曾经想过在电脑上重温那些经典的PS3游戏?或者想要体验那些只能在PlayStation 3上玩…...

Qwen3-VL-8B助力AIGC内容创作:图文匹配与风格一致性检查

Qwen3-VL-8B助力AIGC内容创作:图文匹配与风格一致性检查 最近在折腾AIGC内容创作,我发现一个挺头疼的问题:用模型生成了一大堆图片,怎么快速判断哪张图最符合我的文字描述?或者,一个系列的海报做出来&…...

革命性LLM优化代理OptiLLM:零训练实现2-10倍推理性能提升

革命性LLM优化代理OptiLLM:零训练实现2-10倍推理性能提升 【免费下载链接】optillm Optimizing inference proxy for LLMs 项目地址: https://gitcode.com/gh_mirrors/op/optillm OptiLLM是一款强大的LLM优化代理工具,能够在不进行任何模型训练的…...

青少年软编等考六级题解目录

这个专栏发布中国电子学会主办的青少年软件编程等级考试 C 语言六级题目解析,每篇文章包含一次考试的全部 444 道题目的思路解析。由于考级允许使用 C/C 语言,因此解析中给出的参考代码均为 C 代码。为了方便大家查找,特此发布一篇文章作为目…...

从振荡器到稳定电源:用三阶RC滤波电路讲透控制环路的‘稳定’与‘发散’

从振荡器到稳定电源:三阶RC滤波电路揭示控制环路的稳定性本质 想象一下,你正在调试一个看似简单的三阶RC低通滤波电路。当你逐渐增大放大器的增益时,电路突然从安静的滤波状态转变为持续振荡——原本应该衰减高频信号的电路,现在…...

Phi-3 Forest Lab实战案例:用128K上下文处理整本API文档并生成测试用例

Phi-3 Forest Lab实战案例:用128K上下文处理整本API文档并生成测试用例 1. 项目背景与价值 在现代软件开发中,API文档的处理和测试用例生成是两项耗时且容易出错的工作。传统方法需要工程师手动阅读大量文档并编写测试代码,效率低下且难以保…...

SAP FI年结总账余额结转(FAGLGVTR/F.16)详细注意事项

SAP FI年结总账余额结转(FAGLGVTR/F.16)详细注意事项一、执行前注意事项(核心前提,必查)1. 基础配置与账期检查(重中之重)账期管理:必须通过事务码OB52,确认旧年度1-12期…...

NeMo Voice Agent:零代码构建企业级语音助手的三步解决方案

NeMo Voice Agent:零代码构建企业级语音助手的三步解决方案 【免费下载链接】NeMo NVIDIA/NeMo: 是一个用于实现语音和自然语言处理的开源框架。适合在需要进行语音和自然语言处理的任务中使用。特点是提供了一种简单、易用的 API,支持多种语音和自然语言…...

移动热源坐标参数

comsol激光熔覆仿真模型,热流耦合,包含马兰戈尼非等温模激光熔覆工艺仿真里有个特有意思的物理现象——熔池表面会出现类似水波纹的流动轨迹。这可不是普通的热胀冷缩,而是马兰戈尼效应在金属熔液里跳"物理芭蕾"。咱们今天就用COMS…...

AI 模型推理性能瓶颈与优化方向

AI模型推理性能瓶颈与优化方向 随着AI技术在各行业的广泛应用,模型推理性能成为影响落地效果的关键因素。无论是实时交互场景还是大规模数据处理,推理效率直接决定了用户体验和成本控制。受限于计算资源、算法复杂度及硬件适配性等因素,AI模…...

墨语灵犀处理时序数据实战:基于LSTM的预测模型辅助开发

墨语灵犀处理时序数据实战:基于LSTM的预测模型辅助开发 最近在做一个销量预测的项目,团队里新来的同事看着一长串的时序数据和复杂的LSTM模型代码,有点无从下手。他问我:“这些参数到底该怎么调?预测出来的曲线波动这…...

Qwen3-0.6B-FP8多场景落地:建筑图纸问答+规范条文即时检索系统

Qwen3-0.6B-FP8多场景落地:建筑图纸问答规范条文即时检索系统 1. 引言:当轻量化大模型遇上专业领域 想象一下,你是一位建筑设计师,正在电脑前审阅一份复杂的CAD图纸。你需要快速理解某个构件的尺寸,或者确认某个设计…...

Gemma-3 Pixel Studio开源镜像:CI/CD自动化测试流水线配置

Gemma-3 Pixel Studio开源镜像:CI/CD自动化测试流水线配置 1. 项目概述 Gemma-3 Pixel Studio是基于Google最新开源的Gemma-3-12b-it多模态大模型构建的高性能对话终端应用。它不仅具备强大的文本理解和生成能力,还集成了卓越的视觉理解功能&#xff0…...

电脑卡顿的幕后真相:为什么你的内存总是不够用?

电脑卡顿的幕后真相:为什么你的内存总是不够用? 【免费下载链接】memreduct Lightweight real-time memory management application to monitor and clean system memory on your computer. 项目地址: https://gitcode.com/gh_mirrors/me/memreduct …...

实时风控延迟突增2300ms?揭秘Python部署中被低估的asyncio事件循环阻塞陷阱

第一章:实时风控延迟突增2300ms?揭秘Python部署中被低估的asyncio事件循环阻塞陷阱在某次线上实时风控服务发布后,P99延迟从平均120ms骤升至2420ms,监控图表呈现尖锐毛刺。排查发现,问题并非源于模型推理或数据库慢查询…...

查重率亮红灯反复修改,有哪些真正闭眼可入的的AI智能降重工具推荐?

毕业论文降重,核心在于语义优化 去AI痕迹 降低查重率,工具选择直接影响修改效率。推荐免费与付费工具结合使用,既能节省成本又保证效果。下面按中文、英文、免费/付费分类整理,附上实测效果与适用场景。 一、中文论文降重工具&a…...

playwright-skill解决Web自动化登录难题:从表单交互到会话持久化

playwright-skill解决Web自动化登录难题:从表单交互到会话持久化 【免费下载链接】playwright-skill Claude Code Skill for browser automation with Playwright. Model-invoked - Claude autonomously writes and executes custom automation for testing and val…...

从工具到生态:2026年建站系统深度解析与选型指南

在数字化转型已成为企业标配的今天,建立一个专业的官方网站,早已不是“有没有”的问题,而是“好不好用、能否支撑业务”的深层次考量。对于许多企业管理者、运营人员或创业者来说,“建站系统”这个词或许并不陌生,但当…...

用Python实战N皇后:从回溯的O(n!)到启发式修补的秒解,附完整性能对比代码

用Python实战N皇后:从回溯的O(n!)到启发式修补的秒解,附完整性能对比代码 N皇后问题作为经典的算法挑战,一直是检验编程技巧和算法思维的试金石。当棋盘规模n增大时,不同算法的性能差异会呈现指数级分化——回溯法在n15时可能需要…...

可视化是对比原始数据和填补数据的强大工具。你可以使用箱线图、密度图或散点图来可视化原始数据和填补后的数据

下面的内容摘录自《用R探索医药数据科学》专栏文章的部分内容(原文5665字)。 2篇2章6节:R的多重填补法中随机回归填补法的应用,MICE包的实际应用和统计与可视化评估-CSDN博客 在数据分析中,缺失数据是常见且具有挑战性…...

基于Node.js构建HunyuanVideo-Foley模型调度与管理中间件

基于Node.js构建HunyuanVideo-Foley模型调度与管理中间件 1. 引言:音效生成服务的挑战与机遇 在视频制作和游戏开发领域,高质量的音效生成(HunyuanVideo-Foley)已成为提升作品沉浸感的关键要素。随着AI模型能力的提升,单个音效生成请求的处…...

ResNet50实战:用Fruits-360数据集训练自己的水果分类模型(附完整代码)

ResNet50实战:用Fruits-360数据集训练自己的水果分类模型(附完整代码) 在计算机视觉领域,图像分类是最基础也最实用的任务之一。无论是工业质检、医疗影像分析还是零售商品识别,都需要可靠的分类模型作为支撑。而水果分…...

惊艳!Qwen3-4B-Instruct-2507文本生成效果实测:看看AI能写出什么

惊艳!Qwen3-4B-Instruct-2507文本生成效果实测:看看AI能写出什么 1. 开篇:认识这款强大的文本生成模型 Qwen3-4B-Instruct-2507是阿里开源的最新文本生成大模型,它在多个方面都有显著提升。简单来说,这个AI不仅能理解…...

QMCDecode:解放加密音乐的格式转换专家指南

QMCDecode:解放加密音乐的格式转换专家指南 【免费下载链接】QMCDecode QQ音乐QMC格式转换为普通格式(qmcflac转flac,qmc0,qmc3转mp3, mflac,mflac0等转flac),仅支持macOS,可自动识别到QQ音乐下载目录,默认转换结果存储…...

SecGPT-14B赋能教育行业:高校网络安全实验室AI教学平台搭建

SecGPT-14B赋能教育行业:高校网络安全实验室AI教学平台搭建 1. 引言:当网络安全教学遇上AI大模型 想象一下,在高校的网络安全实验室里,学生面对一个复杂的漏洞分析报告,不再需要花费数小时翻阅厚重的教材和零散的在线…...

PyTorch 2.8镜像实操手册:/workspace+/data+/output目录规范使用详解

PyTorch 2.8镜像实操手册:/workspace/data/output目录规范使用详解 1. 镜像环境概述 PyTorch 2.8深度学习镜像基于RTX 4090D 24GB显卡和CUDA 12.4深度优化,专为高性能计算任务设计。这个环境预装了完整的深度学习工具链,从基础框架到加速库…...

AI智能二维码工坊 vs 传统方案:OpenCV+QRCode性能对比评测

AI智能二维码工坊 vs 传统方案:OpenCVQRCode性能对比评测 二维码,这个黑白相间的小方块,早已渗透进我们生活的方方面面。从扫码支付到添加好友,从产品溯源到活动签到,它无处不在。作为开发者,我们经常需要…...

如何通过智能备份技术实现微信聊天记录的数据主权?本地化管理方案全解析

如何通过智能备份技术实现微信聊天记录的数据主权?本地化管理方案全解析 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_…...