2026年7月9日 周四晚上19:30,报名腾讯会议了解“如何构建自进化的动态知识库(Brain)”(限30人)
免费POC, 零成本试错
FDE知识库

FDE知识库

学习大模型的前沿技术与行业落地应用


收藏

将PDF知识图谱化:graphrag+Doc2X+DeepSeek

发布日期:2024-09-15 16:07:02 浏览次数: 6118
作者:Menghuan的折腾杂记

微信搜一搜,关注“Menghuan的折腾杂记”

微软最近新出了个 graphrag,号称其能提取有意义的结构化数据,不过遗憾的是默认情况下其只能读取txt或者csv数据。这次就让我们用(我写的)外部库pdfdeal将PDF转换为带格式化的txt,再结合更便宜的deepseek进行构建。


安装并配置相应的库

为了避免不必要的麻烦,请使用虚拟环境:

  • miniconda3:conda的最小化安装版本,当然你也可以直接使用Anaconda。

  • uv:一个非常快的包安装程序和解析器,使用Rust构建。

  • 或者我写的调用uv以及conda,达成多版本Python虚拟uv环境的脚本uvv。

#condaconda create -n rag python=3.12conda activate ragpip install --upgrade pdfdeal graphrag
# uvuv venvsource .venv/bin/activate # For Linuxsource .venv/Scripts/activate # For Windowsuv pip install --upgrade graphrag pdfdeal
# uvvuvv create -n rag -p 3.12uvv activate raguvv install graphrag pdfdeal

随后找一个你喜欢的文件夹,准备开始构建吧。


Step1:转换PDF

由于微软这玩意儿只吃txt或者csv,首先我们需要将其转换txt才行。

一般而言有几种转换的选择,效果从最差到最好有:

  • 直接提取纯文本部分转存(效果最差)

  • 提取纯文本部分+图片进行OCR,也就是我写的pdfdeal

  • 干的事情,不过这种方式遇到表格和公式就抓瞎

  • 新型的(识别公式&格式的)OCR工具,一些代表:

    • 闭源(mathpix,Doc2X,simpletex)

    • 开源(nougat,marker)

此处选择了效果最好的Doc2X作为转换的工具(甚至每天免费500页,属于是做慈善了)。首先得获得个人的API密匙,进入网站后通过点击身份信息,复制你的身份令牌作为api即可。

建议使用我的邀请码4AREZ6(手动滑稽)

随后新建两个文件夹,用于存储处理前的PDF以及处理后的txt文件:

mkdir ./pdfmkdir -p ./ragtest/input

随后把要处理的pdf丢到pdf文件夹中,此处我选择的是巨硬的graphrag论文本身以及随机选了一个我感觉很重要的参考文献。

使用pdfdeal的CLI工具doc2x进行批处理,其中记得加上长标示--graphrag以启用对graphrag的特殊适配:

doc2x -k "Your Key Here" -o ./ragtest/input -p --graphrag ./pdf

等待其处理完成,就将所有的PDF文件转换为带格式(指md语法)的txt文档了:


Step2:构建知识图谱(DeepSeek)

首先生成一下graphrag的配置文件,让我们对其进行修改一下使用DeepSeek:

python -m graphrag.index --init --root ./ragtest

如果你只打算使用默认的OpenAI的LLM以及嵌入模型,你仅需要修改.env中的Key就好了。 剧透提醒:graphrag的token消耗即为恐怖,不建议使用默认的gpt-4进行构建

settings.yaml文件,这就是我们需要修改的文件了。

我们需要修改两个部分,第一个部分为llm,由于deepseek并不支持直接输出JSON,记得修改model_supports_jsonfalse

llm:  api_key: Your DeepSeek Key  type: openai_chat # or azure_openai_chat  model: deepseek-chat  model_supports_json: false # recommended if this is available for your model.  max_tokens: 4000  api_base: https://api.deepseek.com/v1

随后修改嵌入部分,此处我直接使用的是OpenAI的text-embedding-3-small。注意,由于llm中我们修改了api_base的值,嵌入中的api_base也需要相应修改,你可以改为任何兼容OpenAI格式的嵌入模型,例如智谱的嵌入模型:

embeddings:  ## parallelization: override the global parallelization settings for embeddings  async_mode: threaded # or asyncio  llm:    api_key: ${GRAPHRAG_API_KEY}    type: openai_embedding # or azure_openai_embedding    model: text-embedding-3-small    api_base: https://api.openai.com/v1
随后输入命令,就是漫长的构建过程了(这两篇不算长PDF花了十几分钟!),去喝杯茶吧:
python -m graphrag.index --root ./ragtest

随后就可以对graphrag发起提问了,注意其分为globallocal两种模式:

python -m graphrag.query \--root ./ragtest \--method global \//或者使用local模式,换成:--method local \"Q"

总结

由于效果部分实在是太长了,总结就放前面了。

graphrag有效果吗?有,尤其是在有关联性的问题上效果非常明显,与Doc2X配合可以相当好的提取文档中的内容。

问题就出在:这是一个token杀手,不管是构建还是在回答阶段

统计这两个PDF文件的内容,如果直接放上下文中的话,加起来会消耗52525token,而以下是构建阶段消耗的token:

2024-07-14,deepseek-chat,graphrag,sk-b30da***********************283e,1334747,344702,1148

消耗了133万输入token,34万输出token。

虽然使用的Deepseek,仅花费了$0.28(¥2.02),但是如果使用OpenAI的模型,即使是较为便宜的gpt-4o也需要$11.85(¥85.92)才能完成构建。

甚至于回答一个问题简单的问题,都会花费输入85293token,输出1848token。不过好在还有deepseek这个性能足够,并且非常便宜的异类来以支撑使用。

同时,由于消耗的token相当恐怖,实际的输出速度也很慢。因此现阶段,graphrag恐怕不像是某些地方所说的RAG解决方案,仅仅作为这个方向是可行的一个demo。


效果

从这儿往下就是实际的效果演示啦。

用的问题为:

讨论使用 LLM 生成图索引和回答用户查询的局限性。在 Graph RAG 方法的未来迭代中如何解决这些限制?

graphrag(使用DeepSeek-Chat进行构建),global模式

deepseek-chat

gpt-4o

graphrag(使用DeepSeek-Chat进行构建),local模式

deepseek-chat

gpt-4o

Dify

作为对比,我加入了Dify的结果。注意,此处的Dify是按照这个流程配置的,使用带Rerank模型的完全体RAG流程。其中提示词等直接使用的默认模板,并未改动。

deepseek-chat

gpt-4o

53AI,企业落地大模型首选服务商

产品:场景落地咨询+大模型应用平台+行业解决方案

承诺:免费POC验证,效果达标后再合作。零风险落地应用大模型,已交付160+中大型企业

联系我们

售前咨询
186 6662 7370
预约演示
185 8882 0121

微信扫码

添加专属顾问

回到顶部

加载中...

扫码咨询

扫码登录
登录即表示您同意《53AI网站服务协议》
服务协议

欢迎您使用【53AI 官方网站】(以下简称“本网站”或“我们”)。本《会员服务协议》(以下简称“本协议”)是您(以下简称“会员”或“用户”)与【深圳市博思协创网络科技有限公司】之间关于注册、登录及使用本网站会员服务所订立的法律协议。

在您注册或登录前,请务必审慎阅读、充分理解各条款内容,特别是免除或限制责任的条款、知识产权条款、争议解决条款等。此类条款将以加粗形式提示您注意。 当您通过微信公众号授权、手机验证码验证或其他方式成功登录本网站时,即视为您已完全理解并同意接受本协议的全部内容。

一、 定义

本网站:指由【深圳市博思协创网络科技有限公司】运营的,域名为【53ai.com】的网站及相关移动端页面。

会员服务:指本网站向注册会员提供的知识库文章查阅、内容检索及其他相关增值服务。

知识库内容:指本网站发布的包括但不限于文字、图表、数据、研究报告、行业分析等数字化内容资源。

二、 账号注册与登录

登录方式:本网站支持以下登录方式,您可根据实际情况选择:

微信公众号授权登录:您同意将您的微信OpenID信息授权给本网站,用于创建或关联会员账号。

手机验证码登录:您需提供真实有效的手机号码,并通过短信验证码完成身份验证与登录/注册。

账号安全:您的账号仅限您本人使用,禁止赠与、借用、租用、转让或售卖。因您保管不善导致的账号被盗、密码泄露等损失,由您自行承担。

实名认证:根据相关法律法规要求,我们可能要求您在特定功能下完成实名认证。如您拒绝提供,可能无法使用部分或全部服务。

未成年人保护:若您未满18周岁,请在法定监护人的陪同下阅读本协议,并在征得监护人同意后使用本服务。

三、 服务内容与规范

知识库查阅权限:会员登录后,有权按照其会员等级对应的权限范围,在线浏览、检索本网站知识库中的相关文章及内容。

服务变更:我们有权根据业务发展需要,调整、变更或终止部分服务内容,并将以网站公告、公众号消息等方式提前通知。

禁止行为:您在使用服务时不得实施以下行为:

利用技术手段批量爬取、下载、转存知识库内容;

将知识库内容用于商业目的或未经授权地向第三方传播;

干扰本网站正常运行或侵犯其他用户合法权益;

发布违法违规信息或从事违反公序良俗的活动。

四、 知识产权声明

权利归属:本网站知识库中的排版设计、软件代码等内容的知识产权均归【公司全称】或原权利人所有,受《中华人民共和国著作权法》等法律保护。

有限许可:本网站授予会员一项非独占、不可转让、不可转授权的普通许可,仅限于个人学习、研究之目的在线查阅知识库内容。

侵权追责:未经书面许可,任何单位或个人不得以任何形式复制、转载、摘编、镜像、汇编或以其他方式使用上述内容。一经发现,我们保留追究其法律责任的权利。

五、 个人信息保护

我们重视对您个人信息的保护。关于我们如何收集、使用、存储和保护您的个人信息,请单独阅读 《隐私政策》。

您通过微信公众号授权或手机号验证所提供的信息,我们将严格按照《个人信息保护法》的规定处理,仅用于身份识别、服务提供及安全验证等必要用途。

您可以随时通过网站设置或联系客服行使查阅、更正、删除个人信息及撤回授权同意的权利。

六、 免责声明

内容准确性:知识库内容仅供参考,不构成专业建议。我们不对其完整性、准确性、时效性作任何明示或暗示的保证,您应自行判断并承担使用风险。

不可抗力:因自然灾害、政策法规变化、网络故障、第三方平台接口异常(如微信接口维护、运营商短信通道故障)等不可抗力导致的服务中断或延迟,我们不承担违约责任。

第三方链接:本网站可能包含指向第三方网站的链接,该等网站的内容和服务不受我们控制,请您自行甄别风险。

七、 违约责任

如您违反本协议约定,我们有权视情节采取警告、限制功能、暂停服务、注销账号等措施,并保留要求赔偿损失的权利。

如因您的违约行为导致我们遭受行政处罚、第三方索赔或商誉损失,您应承担全部赔偿责任(包括但不限于罚款、赔偿金、律师费、公证费等)。

八、 法律适用与争议解决

本协议的订立、执行和解释均适用中华人民共和国大陆地区法律。

因本协议产生的或与本协议有关的任何争议,双方应友好协商解决;协商不成的,任何一方均可向【公司所在地】有管辖权的人民法院提起诉讼。

九、 其他

本协议构成双方就本服务达成的完整协议,取代此前任何口头或书面约定。

本协议任一条款被认定为无效或不可执行的,不影响其他条款的效力。

我们对本协议享有最终解释权,并在法律允许的范围内保留随时修改的权利。修改后的协议一经公布即生效,继续使用服务即视为同意修订内容。


已查阅