项目介绍
作为开发者,你一定经历过被遗留代码支配的恐惧。面对成百上千个文件、错综复杂的调用关系,即便是经验丰富的工程师,重构或接手新项目时也常常直呼头大。市面上不乏代码可视化工具,但它们生成的图谱往往只是“看起来很酷炫”,密密麻麻的节点交织在一起,反而增加了认知负担。
Understand-Anything 是一款由 AI 驱动的代码库分析与可视化工具。它最初作为 Claude Code 的强力插件崭露头角,如今已进化为一个支持 14+ 主流 AI 编程平台的通用工具。它通过多 Agent 协作,将冰冷、复杂的项目代码库转化为一个结构清晰、可交互的业务知识图谱,真正解决“代码读得慢、架构看不懂”的痛点。

正如 Understand-Anything 的口号所说:“Graphs that teach > graphs that impress” —— 能传授知识的图谱,远胜过只用来装赞的代码图谱。
核心功能
多 Agent 协作深度扫描:项目内置了 5 个分工明确的 AI Agent。它们各司其职,从项目扫描、文件剖析、架构分析,到最后的导览生成,自动提取文件、类、函数之间的导入与依赖关系,并生成直白的中文功能描述。 三种视角自由切换:
高层概览 (High-level View) :抹去底层技术细节,用直观的业务流展示架构,适合向产品经理(PM)或非技术利益相关者汇报。 学习模式 (Learning/Tour Mode) :这是该项目的一大亮点。AI 会按照代码依赖的逻辑顺序,自动为你规划一条“代码阅读路线”,像导游一样带你一步步理解核心逻辑,新人再也不用盲目翻文件。 深度探索 (Deep Dive) :为核心开发者准备,展示最硬核的依赖链路与架构细节。
变更影响分析 ( /understand-diff) :在提交 Pull Request 或进行代码评审前,最怕牵一发而动全身。该功能可以精准分析你当前修改的代码会波及系统中的哪些上游模块,提前规避线上故障。业务领域知识提取 ( /understand-domain) :它不仅仅分析代码语法,还能逆向提取出业务领域知识(Domain Knowledge)和业务流程,将技术实现完美映射回实际的业务场景中。
使用方法
Understand-Anything 具备极佳的生态兼容性,无论你使用的是 Claude Code、Cursor、GitHub Copilot,还是 Gemini CLI,都能轻松集成。以下以 Claude Code 环境为例介绍基础使用:
1. 安装插件
在你的 AI 终端环境中,一键添加插件:
/plugin marketplace add Lum1104/Understand-Anything
2. 一键分析项目
进入你的项目根目录,运行分析命令。建议加上 --language zh 确保生成的看板和描述全量中文化:
/understand --language zh
3. 启动可视化面板
分析完成后,运行以下命令即可在浏览器中打开基于 React 开发的独立可视化 Dashboard:
/understand-dashboard
示例
为了让你更直观地感受它的核心能力,我们可以通过它在终端或看板背后的交互机制来一窥究竟。
示例 1:利用 AI 诊断特定链路
当你对某段核心业务(例如认证流程)感到困惑时,可以直接使用交互命令,AI 会结合已生成的图谱上下文进行精准解答,而不是盲目猜测。
# 查询项目中的认证与鉴权流向
/understand-chat "这段代码的 JWT 认证和路由拦截流程是怎么样的?请列出核心文件"
AI 结合图谱的返回示例(简化版):
根据项目图谱分析,你的认证流程主要由以下链路承载:
1. [src/middleware/auth.ts] -> 拦截请求,解析 Header 中的 Bearer Token。
2. [src/utils/jwt.ts] -> 验证 Token 有效性并解码用户信息(包含 roles)。
3. [src/routes/user.ts] -> 路由层,应用上述中间件保护敏感接口。
※ 提示:修改 auth.ts 将直接影响 12 个下游路由文件,请务必谨慎。
示例 2. 变更影响分析输出
在你修改了某个底层工具类后,运行影响分析:
/understand-diff
终端输出示例:
[Understand-Anything] 检测到 1 个文件发生变更:
└── src/utils/db.ts (修改了 connectPool 函数)
⚠️ 发现潜在受影响的上游节点(3个):
├── src/services/user.service.ts (直接依赖 - 高风险)
├── src/services/order.service.ts (直接依赖 - 高风险)
└── src/controllers/order.controller.ts (间接依赖 - 中风险)
建议测试范围:用户登录、订单创建、订单查询流水。
优势对比
在代码可视化与分析领域,Understand-Anything 与传统工具相比有着明显的代差优势:
| 图谱可读性 | 强调“传授知识” | |
| 上手门槛 | 开箱即用 | |
| 业务理解 | 能提取业务领域知识 | |
| 联动能力 | 动态联动-diff) 和上下文对话 (-chat)。 |
总结
Understand-Anything 不仅仅是一个代码绘图工具,更是一个配备了全职“技术导游”的现代化代码分析平台。它通过精妙的 Multi-Agent 设计,把复杂的工程代码拉低到人类最舒适的认知维度,完美适合需要快速接手老项目的新人、做架构重构的资深开发,以及需要跨部门沟通的技术管理者。
项目地址: https://github.com/Lum1104/Understand-Anything
这个公众号发布过的历史 开源项目,如果你懒得翻文章一个个找,你直接关注微信公众号:AI牛马自救指南 ,后台对话聊天就行。
夜雨聆风