微信扫码
添加专属顾问
我要投稿
在构建 RAG 知识库时,PDF文档中的表格跨页现象是一个常见挑战。传统方法依赖复杂的逻辑来判断和合并表格,而更简单、高效的方案可以通过 chunk 的存储和上下文管理来解决。
两种表格合并算法
两种算法都基于版面识别判断法。
前提:正确识别版面并去除每页的页眉、页脚。
1. 合并后存储为一个chunk
判断当前页最后一个元素和下一页第一个元素的类型:
示例代码:
def merge_cross_page_tables(tables_per_page):
merged_tables = []
temp_table = None
for page_num, tables in enumerate(tables_per_page):
for table in tables:
if temp_table: # 上一页存在未合并的表格
temp_table += table # 合并表格内容
merged_tables.append({"page": page_num, "table": temp_table})
temp_table = None
else:
temp_table = table
if temp_table: # 表格延续至下一页
continue
return merged_tables
2. 基于分块与描述同步法(推荐)
将跨页表格的两部分分别提取,并生成独立的 chunk,一般第一个表格的描述信息就是第二页表格的描述信息,需要特殊处理就可以实现跨页。
这种方法无需实时合并表格,通过 LLM 在检索时合并上下文中的表格 chunk,完美解决跨页问题。
示例代码:
import pdfplumber
def extract_tables_as_chunks(pdf_path):
chunks = []
prev_table_desc = ""
table_counter = 1
with pdfplumber.open(pdf_path) as pdf:
for page_num, page in enumerate(pdf.pages):
tables = page.extract_tables()
for table in tables:
if prev_table_desc:
desc = f"表格 {table_counter}(延续部分),前页描述:{prev_table_desc}"
prev_table_desc = "" # 重置描述
else:
desc = f"表格 {table_counter}(第1部分)"
prev_table_desc = desc
chunk = {"description": desc, "data": table, "page": page_num + 1}
chunks.append(chunk)
table_counter += 1
return chunks
两种方案的对比
RAG 系统中的应用
存储:将跨页表格分为多个 chunk 存储,确保数据完整。
检索:用户查询时,RAG 系统会同时检索到表格的多个 chunk。
生成:LLM 根据表格的描述和数据自动合并,输出完整表格内容。
优势总结
53AI,企业落地大模型首选服务商
产品:场景落地咨询+大模型应用平台+行业解决方案
承诺:免费场景POC验证,效果验证后签署服务协议。零风险落地应用大模型,已交付160+中大型企业
2025-04-30
聊聊AI智能体框架MetaGPT下的RAG实践
2025-04-30
如何用大模型+RAG给宠物做一个AI健康助手(干货分享)?
2025-04-30
HiRAG:基于层级知识索引和检索的高精度RAG
2025-04-29
教程|通义Qwen 3 +Milvus,混合推理模型才是优化RAG成本的最佳范式
2025-04-29
RAG开发框架LangChain与LlamaIndex对比解析:谁更适合你的AI应用?
2025-04-29
RAG性能暴增20%!清华等推出“以笔记为中心”的深度检索增强生成框架,复杂问答效果飙升
2025-04-29
超神了,ChatWiki 支持GraphRAG,让 AI 具备垂直深度推理能力!
2025-04-29
AI 产品思维:我如何把一个 AI 应用从基础 RAG 升级到 multi-agent 架构
2024-10-27
2024-09-04
2024-07-18
2024-05-05
2024-06-20
2024-06-13
2024-07-09
2024-07-09
2024-05-19
2024-07-07
2025-04-30
2025-04-29
2025-04-29
2025-04-26
2025-04-25
2025-04-22
2025-04-22
2025-04-20