微信扫码
添加专属顾问
微软最近新出了个 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_json为false:
llm:api_key: Your DeepSeek Keytype: openai_chat # or azure_openai_chatmodel: deepseek-chatmodel_supports_json: false # recommended if this is available for your model.max_tokens: 4000api_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 embeddingsasync_mode: threaded # or asynciollm:api_key: ${GRAPHRAG_API_KEY}type: openai_embedding # or azure_openai_embeddingmodel: text-embedding-3-smallapi_base: https://api.openai.com/v1
python -m graphrag.index --root ./ragtest随后就可以对graphrag发起提问了,注意其分为global和local两种模式:
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+中大型企业
2026-07-03
企业级知识图谱项目之:数据库选型
2026-07-02
企业级知识图谱的实体架构治理实践
2026-07-02
一文讲清:“统一语义”、“构建本体”、“AI推理”这三者的关系
2026-07-02
graphify + claude 图谱关系
2026-07-01
把运维能力装进 Qoder,一句话就能定位根因
2026-07-01
Gbrain、GraphRAG、LLM Wiki、Graphify:4 种知识图谱方案怎么选
2026-07-01
一文讲清:本体(Ontology)与语义(Semantics)到底是什么关系?
2026-06-30
从 OOP 到本体:用形式语义支撑 AI 协作方法论
2026-04-07
2026-04-19
2026-04-23
2026-04-22
2026-06-03
2026-04-23
2026-05-26
2026-05-07
2026-05-28
2026-05-23
欢迎您使用【53AI 官方网站】(以下简称“本网站”或“我们”)。本《会员服务协议》(以下简称“本协议”)是您(以下简称“会员”或“用户”)与【深圳市博思协创网络科技有限公司】之间关于注册、登录及使用本网站会员服务所订立的法律协议。
在您注册或登录前,请务必审慎阅读、充分理解各条款内容,特别是免除或限制责任的条款、知识产权条款、争议解决条款等。此类条款将以加粗形式提示您注意。 当您通过微信公众号授权、手机验证码验证或其他方式成功登录本网站时,即视为您已完全理解并同意接受本协议的全部内容。
一、 定义
本网站:指由【深圳市博思协创网络科技有限公司】运营的,域名为【53ai.com】的网站及相关移动端页面。
会员服务:指本网站向注册会员提供的知识库文章查阅、内容检索及其他相关增值服务。
知识库内容:指本网站发布的包括但不限于文字、图表、数据、研究报告、行业分析等数字化内容资源。
二、 账号注册与登录
登录方式:本网站支持以下登录方式,您可根据实际情况选择:
微信公众号授权登录:您同意将您的微信OpenID信息授权给本网站,用于创建或关联会员账号。
手机验证码登录:您需提供真实有效的手机号码,并通过短信验证码完成身份验证与登录/注册。
账号安全:您的账号仅限您本人使用,禁止赠与、借用、租用、转让或售卖。因您保管不善导致的账号被盗、密码泄露等损失,由您自行承担。
实名认证:根据相关法律法规要求,我们可能要求您在特定功能下完成实名认证。如您拒绝提供,可能无法使用部分或全部服务。
未成年人保护:若您未满18周岁,请在法定监护人的陪同下阅读本协议,并在征得监护人同意后使用本服务。
三、 服务内容与规范
知识库查阅权限:会员登录后,有权按照其会员等级对应的权限范围,在线浏览、检索本网站知识库中的相关文章及内容。
服务变更:我们有权根据业务发展需要,调整、变更或终止部分服务内容,并将以网站公告、公众号消息等方式提前通知。
禁止行为:您在使用服务时不得实施以下行为:
利用技术手段批量爬取、下载、转存知识库内容;
将知识库内容用于商业目的或未经授权地向第三方传播;
干扰本网站正常运行或侵犯其他用户合法权益;
发布违法违规信息或从事违反公序良俗的活动。
四、 知识产权声明
权利归属:本网站知识库中的排版设计、软件代码等内容的知识产权均归【公司全称】或原权利人所有,受《中华人民共和国著作权法》等法律保护。
有限许可:本网站授予会员一项非独占、不可转让、不可转授权的普通许可,仅限于个人学习、研究之目的在线查阅知识库内容。
侵权追责:未经书面许可,任何单位或个人不得以任何形式复制、转载、摘编、镜像、汇编或以其他方式使用上述内容。一经发现,我们保留追究其法律责任的权利。
五、 个人信息保护
我们重视对您个人信息的保护。关于我们如何收集、使用、存储和保护您的个人信息,请单独阅读 《隐私政策》。
您通过微信公众号授权或手机号验证所提供的信息,我们将严格按照《个人信息保护法》的规定处理,仅用于身份识别、服务提供及安全验证等必要用途。
您可以随时通过网站设置或联系客服行使查阅、更正、删除个人信息及撤回授权同意的权利。
六、 免责声明
内容准确性:知识库内容仅供参考,不构成专业建议。我们不对其完整性、准确性、时效性作任何明示或暗示的保证,您应自行判断并承担使用风险。
不可抗力:因自然灾害、政策法规变化、网络故障、第三方平台接口异常(如微信接口维护、运营商短信通道故障)等不可抗力导致的服务中断或延迟,我们不承担违约责任。
第三方链接:本网站可能包含指向第三方网站的链接,该等网站的内容和服务不受我们控制,请您自行甄别风险。
七、 违约责任
如您违反本协议约定,我们有权视情节采取警告、限制功能、暂停服务、注销账号等措施,并保留要求赔偿损失的权利。
如因您的违约行为导致我们遭受行政处罚、第三方索赔或商誉损失,您应承担全部赔偿责任(包括但不限于罚款、赔偿金、律师费、公证费等)。
八、 法律适用与争议解决
本协议的订立、执行和解释均适用中华人民共和国大陆地区法律。
因本协议产生的或与本协议有关的任何争议,双方应友好协商解决;协商不成的,任何一方均可向【公司所在地】有管辖权的人民法院提起诉讼。
九、 其他
本协议构成双方就本服务达成的完整协议,取代此前任何口头或书面约定。
本协议任一条款被认定为无效或不可执行的,不影响其他条款的效力。
我们对本协议享有最终解释权,并在法律允许的范围内保留随时修改的权利。修改后的协议一经公布即生效,继续使用服务即视为同意修订内容。