news 2026/4/16 14:59:46

RAG基础:基于markdown_split的Markdown文本分割实战

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
RAG基础:基于markdown_split的Markdown文本分割实战

一、要求实现如下功能:

功能:

  • headers_to_split_on

  • 支出混合的拆块(支持 chunk_size、chunk_overlap)

  • 支持 chunk 元数据

  • markdown 中的代码不拆分

  • 支持strip_headers 参数设置

二、题解

思路解析:

实现思路
1. 分层处理策略 :
- 第一层:使用 MarkdownHeaderTextSplitter 按标题级别分割文本,保留标题结构
- 第二层:对非代码块内容使用 RecursiveCharacterTextSplitter 进行语义分割
- 特殊处理:识别并完整保留代码块,不进行拆分

2. 核心功能实现 :
- 标题分割 :通过 headers_to_split_on 参数定义要分割的标题级别
- 混合拆块 :结合标题分割和字符分割,支持 chunk_size 和 chunk_overlap 参数
- 元数据保留 :在分割过程中传递和保留文档元数据
- 代码块保护 :通过检测代码块标记(```),确保代码块完整性

3. 技术要点 :
- 使用状态机识别代码块的开始和结束
- 对普通文本和代码块采用不同的处理策略
- 保留原始文档的元数据信息
- 支持自定义标题级别和分割参数

代码:

from langchain_text_splitters import MarkdownHeaderTextSplitter,RecursiveCharacterTextSplitter def markdown_split( markdown_text, # 输入的Markdown文本 headers_to_split_on=None, # 要分割的标题级别 chunk_size=500, # 单个块最大字符数 chunk_overlap=100, # 相邻块重叠字符数 code_block_handling=True # 是否保留代码块完整性 ): """ Markdown文本分割函数 Args: markdown_text: 输入的Markdown文本 headers_to_split_on: 要分割的标题级别,格式为[(\"#\", \"一级标题\"), (\"##\", \"二级标题\")] chunk_size: 单个块最大字符数 chunk_overlap: 相邻块重叠字符数 code_block_handling: 是否保留代码块完整性 Returns: 分割后的Document对象列表 """ # 默认标题级别 if headers_to_split_on is None: headers_to_split_on = [ ("#", "一级标题"), ("##", "二级标题"), ("###", "三级标题"), ] # 1. 使用MarkdownHeaderTextSplitter按标题分割 markdown_splitter = MarkdownHeaderTextSplitter( headers_to_split_on=headers_to_split_on, strip_headers=False, return_each_line=False ) # 执行标题分割 header_split_docs = markdown_splitter.split_text(markdown_text) # 2. 初始化递归字符分割器,用于二次分割长内容 text_splitter = RecursiveCharacterTextSplitter( chunk_size=chunk_size, chunk_overlap=chunk_overlap, separators=["\n\n", "\n", "。", "!", "?", ";", ",", " "], length_function=len, is_separator_regex=False ) # 3. 处理每个标题分割后的部分 final_docs = [] for doc in header_split_docs: content = doc.page_content metadata = doc.metadata.copy() # 如果需要保留代码块完整性 if code_block_handling and "```" in content: # 分割代码块和普通文本 parts = [] # current_part = "" in_code_block = False for line in content.split("\n"): if line.startswith("```"): if in_code_block: # 代码块结束 current_part += line + "\n" parts.append((current_part, True)) # True表示是代码块 current_part = "" in_code_block = False else: # 代码块开始 if current_part: parts.append((current_part, False)) # False表示普通文本 current_part = line + "\n" in_code_block = True else: current_part += line + "\n" # 处理最后一个部分 if current_part: parts.append((current_part, False)) # 对普通文本进行分割,保留代码块完整 for part, is_code in parts: if is_code: # 代码块直接添加,不分割 final_docs.append(type(doc)(page_content=part, metadata=metadata)) else: # 普通文本使用递归分割器 sub_docs = text_splitter.create_documents([part]) for sub_doc in sub_docs: # 保留原始元数据 sub_doc.metadata = metadata.copy() final_docs.append(sub_doc) else: # 不需要保留代码块完整性,直接使用递归分割器 sub_docs = text_splitter.create_documents([content]) for sub_doc in sub_docs: # 保留原始元数据 sub_doc.metadata = metadata.copy() final_docs.append(sub_doc) return final_docs with open("测试数据.md",'r',encoding='utf-8')as f: test_markdown=f.read() # 执行分割 result_docs = markdown_split( test_markdown, chunk_size=200, chunk_overlap=50 ) # 输出结果 print("=== markdown_split 分割结果 ===") for i, doc in enumerate(result_docs, 1): print(f"\n块 {i}:") print(f"字符数: {len(doc.page_content)}") print(f"元数据: {doc.metadata}") print(f"内容:\n{doc.page_content}") print("-" * 80)

运行结果:

数据样例已上传。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 11:58:27

食品金属检测机:生产线的最后一道安全哨兵

在食品工业的流水生产线上,金属杂质的现身属于一个不能被忽视忽略不见的潜在风险隐患,从原料进行筛选挑选开始,到成品完成包装,任何一个生产环节都有可能因为设备出现磨损损耗,或者人员在操作时有所疏忽粗心大意&#…

作者头像 李华
网站建设 2026/4/16 15:07:15

ArduPilot 概述

目的和范围 ArduPilot 是一款开源自动驾驶软件系统,旨在控制包括多旋翼飞行器、固定翼飞机、地面车辆、潜艇和天线跟踪器在内的无人驾驶车辆。本文档提供了 ArduPilot 代码库的高级架构概述,重点介绍支撑所有车辆类型的基本系统组织、组件关系和设计模式。 本概述涵盖以下内…

作者头像 李华
网站建设 2026/4/16 12:27:28

端侧识物+离线翻译轻量化模型选型表

模型类型 主流模型名称 模型体积(量化后) 算力需求(NPU) 核心准确率/翻译效果 适配芯片(百元级低功耗) 核心特点(适配穿戴设备) 端侧识物模型(聚焦日常高频场景&a…

作者头像 李华
网站建设 2026/4/16 12:23:49

iPhone 13 Pro 深度解析:配色外观|核心参数|ProMotion 屏幕|影像与视频|续航与充电|官方维修手册要点|二手验机避坑清单(图文版)

🔥 个人主页: 杨利杰YJlio ❄️ 个人专栏: 《Sysinternals实战教程》 《Windows PowerShell 实战》 《WINDOWS教程》 《IOS教程》 《微信助手》 《锤子助手》 《Python》 《Kali Linux》 《那些年未解决的Windows疑难杂症》 🌟 让…

作者头像 李华
网站建设 2026/4/16 15:46:50

CTF从零到一:新手必备工具合集与下载方式,一键直达!

CTF比赛必备常用工具 一、什么是CTF二、比赛中工具的重要性三、常用MISC(杂项)工具 1. Audacity (提取莫斯密码辅助工具)2. stegsolve (图片隐写分析工具)3. QR_Research (二维码工具&#xff0…

作者头像 李华