乐于分享
好东西不私藏

07 | RAG文档切分 Text Splitter

07 | RAG文档切分 Text Splitter
CSV、JSON、PDF、TXT、Markdown等文档都可以通过不同loader变成LangChain的Document。但进入向量库之前,还有一个很关键的步骤:文档切分
Text Splitter 在 RAG 里的位置是这里:
原始资料 -> Document Loader -> Document -> Text Splitter -> chunks -> Embedding -> Vector Store
它不负责读取文件,也不负责向量化。它负责把一个长 Document 切成多个更适合检索的小 Document。
所以 Text Splitter 也和不同后缀的文件类型没有强绑定关系。PDF、Markdown、CSV、TXT,只要前面已经被 loader 处理成 Document,后面都可以继续切。
为什么要切?因为 RAG 检索时,我们通常不想把整篇资料塞给模型,而是希望召回“刚好能回答问题的那一小段”。
比如用户问:未发货订单能不能退款?
系统最好只拿到退款规则相关段落,而不是把发票、会员、商品质量问题一起搬出来。模型不是不能读,主要是没必要给它一坨。

一、准备一份普通 TXT 资料

本篇用一个.txt文档来说明。场景是客服知识库:退款、发票、会员续费、商品质量等售后规则都写在同一份文本里。
from pathlib import Path# 示例文件放在 rag/data 目录,和前面几篇保持一致data_dir = Path("data")data_dir.mkdir(exist_ok=True)kb_path = data_dir / "support_policy.txt"# 准备一份客服知识库文本# 真实项目里,这个文件通常来自客服后台知识库系统或运营维护的文档kb_path.write_text(    "售后知识库说明\n\n"    "一、未发货订单退款\n"    "如果订单还没有发货,用户可以在订单详情页申请退款。系统会自动拦截发货流程,退款通常会在 1 到 3 个工作日内原路退回。"    "如果订单已经进入仓库打包状态,退款申请可能需要人工审核。\n\n"    "二、已发货订单退款\n"    "如果订单已经发货,用户需要先等待商品送达,再根据实际情况申请退货退款。"    "退货时需要保持商品包装完整,并上传物流单号。仓库签收并验货通过后,退款会在 3 到 7 个工作日内退回。\n\n"    "三、发票下载\n"    "电子发票可以在订单详情页下载。如果用户找不到发票入口,可以引导用户进入:我的订单 -> 订单详情 -> 发票信息。"    "如果发票抬头填写错误,需要联系人工客服重新开具。\n\n"    "四、会员自动续费\n"    "会员服务默认不会强制续费。用户如果开通了自动续费,可以在 App 的会员中心关闭。"    "关闭自动续费后,已经购买的会员权益不会立即失效,会持续到当前会员周期结束。\n\n"    "五、商品质量问题\n"    "如果用户收到商品后发现破损、缺件或无法正常使用,需要在签收后 48 小时内提交售后申请。"    "用户需要上传商品照片、外包装照片和问题说明。客服审核通过后,可以安排换货或退款。\n",    encoding="utf-8",)

二、先加载成 Document

TextLoader 适合读取 .txt、日志、纯文本说明这类文件。它会把文本读成 LangChain 的 Document,后面 Text Splitter 就切这个 Document.page_content。
from langchain_community.document_loaders import TextLoaderloader = TextLoader(str(kb_path), encoding="utf-8")documents = loader.load()document = documents[0]print("Document 数量:"len(documents))print("正文长度:"len(document.page_content))print(document.page_content[:300])print(document.metadata)
输出:
Document 数量: 1正文长度: 481售后知识库说明一、未发货订单退款如果订单还没有发货,用户可以在订单详情页申请退款。系统会自动拦截发货流程,退款通常会在 1 到 3 个工作日内原路退回。如果订单已经进入仓库打包状态,退款申请可能需要人工审核。二、已发货订单退款如果订单已经发货,用户需要先等待商品送达,再根据实际情况申请退货退款。退货时需要保持商品包装完整,并上传物流单号。仓库签收并验货通过后,退款会在 3 到 7 个工作日内退回。三、发票下载电子发票可以在订单详情页下载。如果用户找不到发票入口,可以引导用户进入:我的订单 -> 订单详情 -> 发票信息。如果发票抬头填写错误,需要联系人工客服重新开具。四、{'source''data/support_policy.txt'}
注意,现在只有 1 个 Document,里面装着整份客服知识库。
如果直接把它写进向量库,检索出来也会是一大段。用户只是问退款,你却把发票、会员、质量问题都带上,信息量很足,但不够精准。

三、用 RecursiveCharacterTextSplitter 切分

通用文本切分,优先从 RecursiveCharacterTextSplitter 开始。它会按一组分隔符从大到小尝试切:先按段落,再按句子,再按标点,最后才按字符兜底。
from langchain_text_splitters import RecursiveCharacterTextSplittersplitter = RecursiveCharacterTextSplitter(    # 每个 chunk 尽量控制在 180 个字符以内,便于观察切分边界。    chunk_size=180,    # 相邻 chunk 保留 40 个字符重叠,避免规则在切口处断掉。    chunk_overlap=40,    # 默认按字符长度计算 chunk 大小;这里显式写出来,方便理解。    length_function=len,    # separators 不是正则表达式,只是普通字符串分隔符。    is_separator_regex=False,    # 中文文本优先按段落、句号、逗号切分。    separators=["\n\n""。"","" """],    # 把 chunk 在原文中的起始位置写入 metadata["start_index"]。    add_start_index=True,)chunks = splitter.split_documents(documents)print("切分后 chunk 数量:"len(chunks))for i, chunk in enumerate(chunks, start=1):    print("-" * 40)    print("chunk", i, "长度:"len(chunk.page_content))    print(chunk.page_content)    print(chunk.metadata)
输出:
切分后 chunk 数量: 4----------------------------------------chunk 1 长度: 107售后知识库说明一、未发货订单退款如果订单还没有发货,用户可以在订单详情页申请退款。系统会自动拦截发货流程,退款通常会在 1 到 3 个工作日内原路退回。如果订单已经进入仓库打包状态,退款申请可能需要人工审核。{'source''data/support_policy.txt''start_index'0}----------------------------------------chunk 2 长度: 97二、已发货订单退款如果订单已经发货,用户需要先等待商品送达,再根据实际情况申请退货退款。退货时需要保持商品包装完整,并上传物流单号。仓库签收并验货通过后,退款会在 3 到 7 个工作日内退回。{'source''data/support_policy.txt''start_index'109}----------------------------------------chunk 3 长度: 177三、发票下载电子发票可以在订单详情页下载。如果用户找不到发票入口,可以引导用户进入:我的订单 -> 订单详情 -> 发票信息。如果发票抬头填写错误,需要联系人工客服重新开具。四、会员自动续费会员服务默认不会强制续费。用户如果开通了自动续费,可以在 App 的会员中心关闭。关闭自动续费后,已经购买的会员权益不会立即失效,会持续到当前会员周期结束。{'source''data/support_policy.txt''start_index'208}----------------------------------------chunk 4 长度: 93五、商品质量问题如果用户收到商品后发现破损、缺件或无法正常使用,需要在签收后 48 小时内提交售后申请。用户需要上传商品照片、外包装照片和问题说明。客服审核通过后,可以安排换货或退款。{'source''data/support_policy.txt''start_index'387}
切分后的每个 chunk 仍然是 Document。也就是说,它既有:
  • page_content:切出来的小段正文
  • metadata:来源文件、起始位置等信息
这就是 RAG 后面做“引用来源”和“排查召回结果”的基础。

四、chunk_size 和 chunk_overlap

这两个参数要多说两句,
chunk_size 控制每块大概多长,而chunk_overlap 控制相邻两块重叠多少内容。
为什么要重叠?因为一条规则可能刚好卡在切分边界上。如果完全不重叠,前半句在上一块,后半句在下一块,检索时就像把一句话从中间撕开。比如下面的例子:
sample_text = "未发货订单可以直接申请退款系统会自动拦截发货流程如果订单进入仓库打包状态退款申请可能需要人工审核退款通常会在1到3个工作日内原路退回"no_overlap_splitter = RecursiveCharacterTextSplitter(    chunk_size=32,    chunk_overlap=0,    separators=[""],)with_overlap_splitter = RecursiveCharacterTextSplitter(    chunk_size=32,    chunk_overlap=10,    separators=[""],)print("不保留重叠:")for text in no_overlap_splitter.split_text(sample_text):    print(text)print("\n保留 10 个字符重叠:")for text in with_overlap_splitter.split_text(sample_text):    print(text)
输出:
不保留重叠:未发货订单可以直接申请退款系统会自动拦截发货流程如果订单进入仓库打包状态退款申请可能需要人工审核退款通常会在1到3个工作日内原路退回保留 10 个字符重叠:未发货订单可以直接申请退款系统会自动拦截发货流程如果订单进入仓库流程如果订单进入仓库打包状态退款申请可能需要人工审核退款通常会在人工审核退款通常会在1到3个工作日内原路退回

这段输出可以这样看:

chunk_size=32表示每个 chunk 最多大约 32 个字符,所以这段话会被切成 3 块。

不保留重叠时,上一块结尾是:

...如果订单进入仓库

下一块接着突兀的说:

打包状态退款申请可能需要人工审核...

这两块单独看都不完整。尤其第一块停在“进入仓库”,读者还不知道进入仓库之后会怎样。

保留chunk_overlap=10后,下一块会从上一块结尾附近重新带一小段:

流程如果订单进入仓库打包状态...

重叠不是为了重复凑字数,而是为了让下一块带上上一块的尾巴。这样即使检索只命中第二块,也能看到前后关系。

即,没有 overlap,切口很干净,但上下文容易断。  有 overlap,会多存一点重复内容,但检索出来的片段更不容易缺头少尾。

经验上可以先这样选:
不要迷信固定数字。真正要看的是:切出来的 chunk 是否能独立表达一个意思,如果一次切不好,那就多切几次。

五、切完再写入向量库

Text Splitter 本身不负责向量化,也不负责检索。切完以后,再把 chunks 交给 Embedding 和 Vector Store。
from langchain_core.vectorstores import InMemoryVectorStorefrom langchain_ollama import OllamaEmbeddingsembeddings = OllamaEmbeddings(    model="qwen3-embedding:latest",    base_url="http://localhost:11434",)# 注意这里写入的是 chunks,不是原始 documents。# 这样检索返回的是更精确的小段内容。vectorstore = InMemoryVectorStore.from_documents(    documents=chunks,    embedding=embeddings,)results = vectorstore.similarity_search(    "未发货订单能退款吗?",    k=2,)for doc in results:    print(doc.page_content)    print(doc.metadata)    print("-" * 40)
输出:
售后知识库说明一、未发货订单退款如果订单还没有发货,用户可以在订单详情页申请退款。系统会自动拦截发货流程,退款通常会在 1 到 3 个工作日内原路退回。如果订单已经进入仓库打包状态,退款申请可能需要人工审核。{'source''data/support_policy.txt''start_index'0}----------------------------------------二、已发货订单退款如果订单已经发货,用户需要先等待商品送达,再根据实际情况申请退货退款。退货时需要保持商品包装完整,并上传物流单号。仓库签收并验货通过后,退款会在 3 到 7 个工作日内退回。{'source''data/support_policy.txt''start_index'109}----------------------------------------
从这个结果中也可以看到,为了回答“为发货订单能退款吗”,基于overloap它把两个有关联的chunk都给拿出来了。

六、反面示例:不切分会怎样

为了对比一下,现在把原始 documents 直接写进向量库。
注意:原始 documents 只有 1 个 Document,也就是整份 support_policy.txt。
# 这里故意不使用 chunks,而是把完整 documents 写进向量库。raw_vectorstore = InMemoryVectorStore.from_documents(    documents=documents,    embedding=embeddings,)raw_results = raw_vectorstore.similarity_search(    "未发货订单能退款吗?",    k=1,)for doc in raw_results:    print(doc.page_content)    print(doc.metadata)
输出:
售后知识库说明一、未发货订单退款如果订单还没有发货,用户可以在订单详情页申请退款。系统会自动拦截发货流程,退款通常会在 1 到 3 个工作日内原路退回。如果订单已经进入仓库打包状态,退款申请可能需要人工审核。二、已发货订单退款如果订单已经发货,用户需要先等待商品送达,再根据实际情况申请退货退款。退货时需要保持商品包装完整,并上传物流单号。仓库签收并验货通过后,退款会在 3 到 7 个工作日内退回。三、发票下载电子发票可以在订单详情页下载。如果用户找不到发票入口,可以引导用户进入:我的订单 -> 订单详情 -> 发票信息。如果发票抬头填写错误,需要联系人工客服重新开具。四、会员自动续费会员服务默认不会强制续费。用户如果开通了自动续费,可以在 App 的会员中心关闭。关闭自动续费后,已经购买的会员权益不会立即失效,会持续到当前会员周期结束。五、商品质量问题如果用户收到商品后发现破损、缺件或无法正常使用,需要在签收后 48 小时内提交售后申请。用户需要上传商品照片、外包装照片和问题说明。客服审核通过后,可以安排换货或退款。{'source''data/support_policy.txt'}
这时虽然也能检索到相关内容,但返回的是整份售后知识库。
这就是切分前后的差别:
  • 不切分:召回整份资料
  • 切分后:召回相关片段
RAG 不是只要“找得到”,还要“拿得准”。这也是 Text Splitter 存在的核心价值。

这篇只记住几件事

  1. Text Splitter 切的是文本内容,与文件后缀无关,所以源文件可以是 TXT、PDF、Markdown、CSV,只要最后变成 Document,就可以继续切。
  2. 通用文本切分,优先理解 RecursiveCharacterTextSplitter。
  3. chunk_size 控制每块长度。
  4. chunk_overlap 让相邻 chunk 保留一点上下文。
  5. 切完以后,再把 chunks 写入向量库。
基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-06-04 11:00:59 HTTP/1.1 GET : https://www.yeyulingfeng.com/a/704056.html
  2. 运行时间 : 0.179619s [ 吞吐率:5.57req/s ] 内存消耗:4,901.41kb 文件加载:145
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=641cfd7dfa92e2b9d2ab3984f498a96e
  1. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/public/index.php ( 0.79 KB )
  2. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/autoload.php ( 0.17 KB )
  3. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/composer/autoload_real.php ( 2.49 KB )
  4. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/composer/platform_check.php ( 0.90 KB )
  5. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/composer/ClassLoader.php ( 14.03 KB )
  6. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/composer/autoload_static.php ( 6.05 KB )
  7. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/helper.php ( 8.34 KB )
  8. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-validate/src/helper.php ( 2.19 KB )
  9. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/ralouphie/getallheaders/src/getallheaders.php ( 1.60 KB )
  10. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/helper.php ( 1.47 KB )
  11. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/stubs/load_stubs.php ( 0.16 KB )
  12. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Exception.php ( 1.69 KB )
  13. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-container/src/Facade.php ( 2.71 KB )
  14. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/symfony/deprecation-contracts/function.php ( 0.99 KB )
  15. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/symfony/polyfill-mbstring/bootstrap.php ( 8.26 KB )
  16. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/symfony/polyfill-mbstring/bootstrap80.php ( 9.78 KB )
  17. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/symfony/var-dumper/Resources/functions/dump.php ( 1.49 KB )
  18. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-dumper/src/helper.php ( 0.18 KB )
  19. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/symfony/var-dumper/VarDumper.php ( 4.30 KB )
  20. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/guzzlehttp/guzzle/src/functions_include.php ( 0.16 KB )
  21. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/guzzlehttp/guzzle/src/functions.php ( 5.54 KB )
  22. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/App.php ( 15.30 KB )
  23. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-container/src/Container.php ( 15.76 KB )
  24. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/psr/container/src/ContainerInterface.php ( 1.02 KB )
  25. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/provider.php ( 0.19 KB )
  26. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Http.php ( 6.04 KB )
  27. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/helper/Str.php ( 7.29 KB )
  28. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Env.php ( 4.68 KB )
  29. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/common.php ( 0.03 KB )
  30. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/helper.php ( 18.78 KB )
  31. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Config.php ( 5.54 KB )
  32. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/alipay.php ( 3.59 KB )
  33. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/facade/Env.php ( 1.67 KB )
  34. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/app.php ( 0.95 KB )
  35. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/cache.php ( 0.78 KB )
  36. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/console.php ( 0.23 KB )
  37. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/cookie.php ( 0.56 KB )
  38. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/database.php ( 2.48 KB )
  39. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/filesystem.php ( 0.61 KB )
  40. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/lang.php ( 0.91 KB )
  41. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/log.php ( 1.35 KB )
  42. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/middleware.php ( 0.19 KB )
  43. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/route.php ( 1.89 KB )
  44. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/session.php ( 0.57 KB )
  45. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/trace.php ( 0.34 KB )
  46. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/view.php ( 0.82 KB )
  47. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/event.php ( 0.25 KB )
  48. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Event.php ( 7.67 KB )
  49. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/service.php ( 0.13 KB )
  50. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/AppService.php ( 0.26 KB )
  51. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Service.php ( 1.64 KB )
  52. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Lang.php ( 7.35 KB )
  53. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/lang/zh-cn.php ( 13.70 KB )
  54. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/initializer/Error.php ( 3.31 KB )
  55. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/initializer/RegisterService.php ( 1.33 KB )
  56. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/services.php ( 0.14 KB )
  57. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/service/PaginatorService.php ( 1.52 KB )
  58. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/service/ValidateService.php ( 0.99 KB )
  59. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/service/ModelService.php ( 2.04 KB )
  60. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-trace/src/Service.php ( 0.77 KB )
  61. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Middleware.php ( 6.72 KB )
  62. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/initializer/BootService.php ( 0.77 KB )
  63. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/Paginator.php ( 11.86 KB )
  64. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-validate/src/Validate.php ( 63.20 KB )
  65. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/Model.php ( 23.55 KB )
  66. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/Attribute.php ( 21.05 KB )
  67. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/AutoWriteData.php ( 4.21 KB )
  68. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/Conversion.php ( 6.44 KB )
  69. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/DbConnect.php ( 5.16 KB )
  70. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/ModelEvent.php ( 2.33 KB )
  71. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/RelationShip.php ( 28.29 KB )
  72. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/contract/Arrayable.php ( 0.09 KB )
  73. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/contract/Jsonable.php ( 0.13 KB )
  74. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/contract/Modelable.php ( 0.09 KB )
  75. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Db.php ( 2.88 KB )
  76. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/DbManager.php ( 8.52 KB )
  77. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Log.php ( 6.28 KB )
  78. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Manager.php ( 3.92 KB )
  79. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/psr/log/src/LoggerTrait.php ( 2.69 KB )
  80. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/psr/log/src/LoggerInterface.php ( 2.71 KB )
  81. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Cache.php ( 4.92 KB )
  82. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/psr/simple-cache/src/CacheInterface.php ( 4.71 KB )
  83. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/helper/Arr.php ( 16.63 KB )
  84. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/cache/driver/File.php ( 7.84 KB )
  85. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/cache/Driver.php ( 9.03 KB )
  86. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/contract/CacheHandlerInterface.php ( 1.99 KB )
  87. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/Request.php ( 0.09 KB )
  88. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Request.php ( 55.78 KB )
  89. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/middleware.php ( 0.25 KB )
  90. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Pipeline.php ( 2.61 KB )
  91. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-trace/src/TraceDebug.php ( 3.40 KB )
  92. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/middleware/SessionInit.php ( 1.94 KB )
  93. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Session.php ( 1.80 KB )
  94. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/session/driver/File.php ( 6.27 KB )
  95. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/contract/SessionHandlerInterface.php ( 0.87 KB )
  96. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/session/Store.php ( 7.12 KB )
  97. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Route.php ( 23.73 KB )
  98. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/RuleName.php ( 5.75 KB )
  99. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/Domain.php ( 2.53 KB )
  100. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/RuleGroup.php ( 22.43 KB )
  101. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/Rule.php ( 26.95 KB )
  102. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/RuleItem.php ( 9.78 KB )
  103. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/route/app.php ( 3.94 KB )
  104. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/facade/Route.php ( 4.70 KB )
  105. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/dispatch/Controller.php ( 4.74 KB )
  106. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/Dispatch.php ( 10.44 KB )
  107. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/controller/Index.php ( 9.87 KB )
  108. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/BaseController.php ( 2.05 KB )
  109. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/facade/Db.php ( 0.93 KB )
  110. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/connector/Mysql.php ( 5.44 KB )
  111. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/PDOConnection.php ( 52.47 KB )
  112. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/Connection.php ( 8.39 KB )
  113. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/ConnectionInterface.php ( 4.57 KB )
  114. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/builder/Mysql.php ( 16.58 KB )
  115. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/Builder.php ( 24.06 KB )
  116. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/BaseBuilder.php ( 27.50 KB )
  117. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/Query.php ( 15.71 KB )
  118. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/BaseQuery.php ( 45.13 KB )
  119. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/TimeFieldQuery.php ( 7.43 KB )
  120. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/AggregateQuery.php ( 3.26 KB )
  121. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/ModelRelationQuery.php ( 20.07 KB )
  122. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/ParamsBind.php ( 3.66 KB )
  123. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/ResultOperation.php ( 7.01 KB )
  124. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/WhereQuery.php ( 19.37 KB )
  125. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/JoinAndViewQuery.php ( 7.11 KB )
  126. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/TableFieldInfo.php ( 2.63 KB )
  127. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/Transaction.php ( 2.77 KB )
  128. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/log/driver/File.php ( 5.96 KB )
  129. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/contract/LogHandlerInterface.php ( 0.86 KB )
  130. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/log/Channel.php ( 3.89 KB )
  131. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/event/LogRecord.php ( 1.02 KB )
  132. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/Collection.php ( 16.47 KB )
  133. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/facade/View.php ( 1.70 KB )
  134. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/View.php ( 4.39 KB )
  135. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/controller/Es.php ( 3.30 KB )
  136. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Response.php ( 8.81 KB )
  137. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/response/View.php ( 3.29 KB )
  138. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Cookie.php ( 6.06 KB )
  139. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-view/src/Think.php ( 8.38 KB )
  140. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/contract/TemplateHandlerInterface.php ( 1.60 KB )
  141. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-template/src/Template.php ( 46.61 KB )
  142. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-template/src/template/driver/File.php ( 2.41 KB )
  143. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-template/src/template/contract/DriverInterface.php ( 0.86 KB )
  144. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/runtime/temp/c935550e3e8a3a4c27dd94e439343fdf.php ( 31.50 KB )
  145. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-trace/src/Html.php ( 4.42 KB )
  1. CONNECT:[ UseTime:0.000810s ] mysql:host=127.0.0.1;port=3306;dbname=wenku;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.001525s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000568s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000544s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.001052s ]
  6. SELECT * FROM `set` [ RunTime:0.000393s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.001323s ]
  8. SELECT * FROM `article` WHERE `id` = 704056 LIMIT 1 [ RunTime:0.000916s ]
  9. UPDATE `article` SET `lasttime` = 1780542059 WHERE `id` = 704056 [ RunTime:0.018166s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 64 LIMIT 1 [ RunTime:0.000544s ]
  11. SELECT * FROM `article` WHERE `id` < 704056 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.001251s ]
  12. SELECT * FROM `article` WHERE `id` > 704056 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.000999s ]
  13. SELECT * FROM `article` WHERE `id` < 704056 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.002165s ]
  14. SELECT * FROM `article` WHERE `id` < 704056 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.002515s ]
  15. SELECT * FROM `article` WHERE `id` < 704056 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.007837s ]
0.182812s