news 2026/4/16 11:58:41

langchain递归切片器原理分析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
langchain递归切片器原理分析

机制分析

关键文件和类

文件路径:langchain_text_splitters/character.py

类名:RecursiveCharacterTextSplitter

核心入口函数:_split_text

解析步骤及源码分析

步骤说明示例/细节
1. 分隔符降级separators=["\n\n", "\n", " ", ""]顺序尝试,分隔符可自定义先用\n\n切段落,若任一段>chunk_size 字符,则对该段降级使用\n切,依次类推
2. 递归切分对“超长段”重复步骤 1,直到所有片段 ≤ chunk_size 或已用完分隔符若句子级仍超长,最终用空字符串""按字符硬切
3. 段合并(Merge)把“好段”依次拼成尽可能长的块,保证 ≤ chunk_size如果拼到再加就超chunk_size,则封口、起新块
4. 重叠(Overlap)当合并完成一个块A1之后,算法回退<=chunk_overlap的长度,以便下个块A2包含前一个块末尾overlap的内容。特别的,若块A1的最后一段长度大于chunk_overlap,则为保证语义完整,不强行生成overlap。相邻两个块 A1和A2,则 A2 头部 = A1 尾部 overlap 内容

上述步骤的总体逻辑在_split_text函数中,关键处均有代码注释说明:

def_split_text(self,text:str,separators:list[str])->list[str]:"""Split incoming text and return chunks."""final_chunks=[]# Get appropriate separator to use# 得到当前层级的分隔符separator=separators[-1]new_separators=[]fori,_sinenumerate(separators):_separator=_sifself._is_separator_regexelsere.escape(_s)if_s=="":separator=_sbreak# 快速搜索文本中是否存在分隔符,不存在,则分隔符降级ifre.search(_separator,text):separator=_s new_separators=separators[i+1:]break_separator=separatorifself._is_separator_regexelsere.escape(separator)splits=_split_text_with_regex(text,_separator,keep_separator=self._keep_separator)# Now go merging things, recursively splitting longer texts.# 所谓的“好段”指的是长度小于chunk_size的段_good_splits=[]_separator=""ifself._keep_separatorelseseparatorforsinsplits:ifself._length_function(s)<self._chunk_size:_good_splits.append(s)else:# 如果发现一个段不是好段,就把前面累积的好段做合并if_good_splits:merged_text=self._merge_splits(_good_splits,_separator)final_chunks.extend(merged_text)_good_splits=[]ifnotnew_separators:# 这里看似会生成一个超长块,但考虑到最后一个分隔符是空(亦即按字符切分),这行代码其实是跑不到的。final_chunks.append(s)else:# 对于超长段,用下级分隔符递归切分other_info=self._split_text(s,new_separators)final_chunks.extend(other_info)if_good_splits:merged_text=self._merge_splits(_good_splits,_separator)final_chunks.extend(merged_text)returnfinal_chunks

合并与重叠的逻辑则在_merge_splits函数中,关键处均有代码注释说明:

def_merge_splits(self,splits:Iterable[str],separator:str)->list[str]:# We now want to combine these smaller pieces into medium size# chunks to send to the LLM.separator_len=self._length_function(separator)docs=[]current_doc:list[str]=[]total=0# splits是所谓的好段,我们将好段尽可能拼接为较大的块fordinsplits:_len=self._length_function(d)# 拼到再加就超chunk_size,则封口、起新块if(total+_len+(separator_leniflen(current_doc)>0else0)>self._chunk_size):iftotal>self._chunk_size:logger.warning(f"Created a chunk of size{total}, "f"which is longer than the specified{self._chunk_size}")iflen(current_doc)>0:doc=self._join_docs(current_doc,separator)ifdocisnotNone:docs.append(doc)# Keep on popping if:# - we have a larger chunk than in the chunk overlap# - or if we still have any chunks and the length is long# 这一段是overlap的核心处理逻辑# 算法回退<=chunk_overlap的长度,以便下个块A2包含前一个块A1末尾overlap的内容。特别的,若块A1的最后一段长度大于chunk_overlap,则为保证语义完整,不会生成overlap。current_doc里存的就是一个块的所有段。whiletotal>self._chunk_overlapor(total+_len+(separator_leniflen(current_doc)>0else0)>self._chunk_sizeandtotal>0):total-=self._length_function(current_doc[0])+(separator_leniflen(current_doc)>1else0)current_doc=current_doc[1:]current_doc.append(d)total+=_len+(separator_leniflen(current_doc)>1else0)doc=self._join_docs(current_doc,separator)ifdocisnotNone:docs.append(doc)returndocs
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/14 9:46:56

RestAPI

一、定义 REST&#xff08;Representational State Transfer&#xff09;表述性状态转换&#xff0c;REST指的是一组架构约束条件和原则。 如果一个架构符合REST的约束条件和原则&#xff0c;我们就称它为RESTful架构。REST本身并没有创造新的技术、组件或服务&#xff0c;而隐…

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

物流效率提升300%的秘密武器(量子Agent路径优化全解析)

第一章&#xff1a;物流量子 Agent 的路径优化在现代物流系统中&#xff0c;路径优化是提升运输效率、降低能耗的关键环节。传统算法如 Dijkstra 或遗传算法在面对大规模节点网络时存在计算复杂度高、收敛速度慢的问题。近年来&#xff0c;基于量子计算思想的智能 Agent 技术为…

作者头像 李华
网站建设 2026/4/15 14:02:53

Depth Anything V2深度估计实战指南:从零构建智能视觉应用

Depth Anything V2深度估计实战指南&#xff1a;从零构建智能视觉应用 【免费下载链接】Depth-Anything-V2 Depth Anything V2. A More Capable Foundation Model for Monocular Depth Estimation 项目地址: https://gitcode.com/gh_mirrors/de/Depth-Anything-V2 想要让…

作者头像 李华
网站建设 2026/4/10 2:45:29

宝可梦数据合规化终极指南:快速掌握自动化合规工具

宝可梦数据合规化终极指南&#xff1a;快速掌握自动化合规工具 【免费下载链接】PKHeX-Plugins Plugins for PKHeX 项目地址: https://gitcode.com/gh_mirrors/pk/PKHeX-Plugins 在宝可梦数据处理领域&#xff0c;AutoLegalityMod作为一款专业的自动化合规工具&#xff…

作者头像 李华
网站建设 2026/4/2 2:25:04

django基于python的时光网电影信息数据可视化分析系统设计与实现_8re776u9

文章目录系统截图项目技术简介可行性分析主要运用技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;系统截图 djangopython_8re776u9 的时光网电影信息数据可视化分析系统设计与实现基于 项目技术简介 …

作者头像 李华
网站建设 2026/4/8 18:59:16

django基于python的电影推荐系统设计与实现_83632ix7

文章目录系统截图项目技术简介可行性分析主要运用技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;系统截图 djangopython_83632ix7 的电影推荐系统设计与实现基于 项目技术简介 Python版本&#xff1a;…

作者头像 李华