Marketplace project-to-obsidian
git clone https://github.com/aiskillstore/marketplace
T=$(mktemp -d) && git clone --depth=1 https://github.com/aiskillstore/marketplace "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/zhanlincui/project-to-obsidian" ~/.claude/skills/aiskillstore-marketplace-project-to-obsidian && rm -rf "$T"
skills/zhanlincui/project-to-obsidian/SKILL.mdProject to Obsidian - 项目知识库生成器
将任意代码项目转换为结构化的 Obsidian 知识库,让项目知识可搜索、可链接、可扩展。
🎯 核心功能
| 命令 | 功能 | 说明 |
|---|---|---|
| 完整转换 | 分析项目并生成完整 Obsidian 库 |
| 快速概览 | 只生成项目概览和结构 |
| API 文档 | 专注生成 API/函数文档 |
| 架构文档 | 生成架构和设计文档 |
⚡ 执行流程
用户意图: "把这个项目转成知识库" / /p2o ↓ ┌─────────────────────────────────────────────────────────┐ │ PHASE 0: 用户确认(必须) │ │ │ │ Claude 使用 AskUserQuestion 工具询问: │ │ │ │ "检测到你想将项目转换为 Obsidian 知识库,请确认:" │ │ │ │ 📁 项目路径: /path/to/project │ │ │ │ 选择输出方式: │ │ [1] 写入 Obsidian vault(需要 MCP) │ │ [2] 创建本地文件夹 │ │ [3] 输出到项目 /docs 目录 │ │ [4] 取消 │ │ │ │ 用户选择后才继续执行。 │ └─────────────────────────────────────────────────────────┘ ↓ 用户确认后 ↓ ┌─────────────────────────────────────────────────────────┐ │ PHASE 1: 项目扫描 │ │ ├─ 读取项目结构 (Glob + Bash ls/find) │ │ ├─ 识别项目类型 (package.json/Cargo.toml/go.mod 等) │ │ ├─ 检测主要语言和框架 │ │ └─ 生成文件清单 │ └─────────────────────────────────────────────────────────┘ ↓ ┌─────────────────────────────────────────────────────────┐ │ PHASE 2: 代码分析 │ │ ├─ 读取关键文件 (入口、配置、核心模块) │ │ ├─ 提取: │ │ │ ├─ 函数/类/接口定义 │ │ │ ├─ API 端点 │ │ │ ├─ 依赖关系 │ │ │ ├─ 配置项 │ │ │ └─ 注释和文档字符串 │ │ └─ 构建代码知识图谱 │ └─────────────────────────────────────────────────────────┘ ↓ ┌─────────────────────────────────────────────────────────┐ │ PHASE 3: 文档生成 │ │ ├─ 生成 Obsidian 目录结构 │ │ ├─ 创建各类文档: │ │ │ ├─ 00-项目概览.md (MOC) │ │ │ ├─ 01-快速开始.md │ │ │ ├─ 02-架构设计.md │ │ │ ├─ 03-API文档/ │ │ │ ├─ 04-模块说明/ │ │ │ ├─ 05-配置参考.md │ │ │ └─ 06-开发指南.md │ │ └─ 添加双向链接 [[]] 和标签 #tag │ └─────────────────────────────────────────────────────────┘ ↓ ┌─────────────────────────────────────────────────────────┐ │ PHASE 4: 输出到 Obsidian │ │ ├─ 方式A: 写入 00_Inbox/AI/{{项目名}}/ (推荐,先落地) │ │ ├─ 方式B: 写入 30_Resources/Projects/{{项目名}}/ │ │ └─ 方式C: 创建本地文件夹 │ └─────────────────────────────────────────────────────────┘ ↓ 完成报告
⚠️ AI 写入规则(必须遵守)
规则 1: 默认落地到 AI 专区
首选位置: 00_Inbox/AI/{{项目名}}-知识库/ 用户确认后可移动到: 30_Resources/Projects/
规则 2: 使用追加式写入
✅ obsidian_append_content - 创建新文件 ✅ obsidian_patch_content - 追加到指定位置 ❌ 不要覆盖已存在的笔记
规则 3: 统一 Properties Schema
# 项目文档统一使用以下字段 --- type: project-doc # project-doc | api | module | architecture project: "{{项目名}}" source: "{{项目路径}}" language: "" # typescript | python | go | rust | java framework: "" # react | express | fastapi | gin tags: [] created: {{date}} ---
规则 4: 生成 Dataview 索引
在项目概览中自动添加 Dataview 查询: - 模块列表 - API 端点列表 - 最近修改
📋 详细执行步骤
STEP 0: 用户确认(必须先执行)
当 skill 被触发时,Claude 必须首先使用 AskUserQuestion 工具询问用户:
AskUserQuestion: question: "检测到你想将项目转换为 Obsidian 知识库" header: "确认" options: - label: "写入 Obsidian vault" description: "使用 MCP 直接写入你的 Obsidian 库(推荐)" - label: "创建本地文件夹" description: "在指定位置创建新的知识库文件夹" - label: "输出到 /docs" description: "在当前项目目录下创建 docs/obsidian/" - label: "取消" description: "不执行转换"
用户选择「取消」时,立即停止,不执行后续步骤。
用户确认后,继续显示项目信息并询问生成模式:
AskUserQuestion: question: "选择生成模式" header: "模式" options: - label: "完整模式" description: "生成全部文档:概览、架构、API、模块说明" - label: "快速模式" description: "只生成项目概览和目录结构" - label: "API 文档" description: "专注生成 API/接口文档"
STEP 1: 项目扫描
# Claude 执行的分析逻辑 # 1. 获取项目结构 使用 Glob 工具扫描: - **/*.{js,ts,py,go,rs,java,rb,php,swift,kt} # 代码文件 - **/package.json, **/Cargo.toml, **/go.mod # 项目配置 - **/*.{md,txt} # 文档 - **/.env*, **/config.* # 配置文件 # 2. 识别项目类型 检测标志文件: - package.json → Node.js/前端项目 - Cargo.toml → Rust 项目 - go.mod → Go 项目 - pyproject.toml/setup.py → Python 项目 - pom.xml/build.gradle → Java 项目 - Gemfile → Ruby 项目 # 3. 识别框架 检测特征: - next.config.* → Next.js - vite.config.* → Vite - tsconfig.json → TypeScript - Dockerfile → Docker 化项目 - .github/workflows → CI/CD
STEP 3: 代码分析
对每个关键文件,Claude 需要提取: ├─ 入口文件 (main.*, index.*, app.*) │ ├─ 应用初始化流程 │ ├─ 路由配置 │ └─ 中间件设置 │ ├─ API/路由文件 │ ├─ 端点路径 │ ├─ HTTP 方法 │ ├─ 请求参数 │ └─ 响应格式 │ ├─ 模型/类型定义 │ ├─ 数据结构 │ ├─ 接口定义 │ └─ 类型别名 │ ├─ 服务/业务逻辑 │ ├─ 核心函数 │ ├─ 业务流程 │ └─ 外部调用 │ └─ 配置文件 ├─ 环境变量 ├─ 功能开关 └─ 第三方配置
STEP 4: 生成 Obsidian 结构
生成的 Obsidian 目录结构: {{项目名}}-知识库/ ├─ 00-项目概览.md # MOC - 主入口 ├─ 01-快速开始.md # 安装、运行、基本使用 ├─ 02-架构设计/ │ ├─ 整体架构.md │ ├─ 目录结构.md │ └─ 技术栈.md ├─ 03-API文档/ │ ├─ _API索引.md # API MOC │ ├─ 用户相关.md │ ├─ 订单相关.md │ └─ ... ├─ 04-模块说明/ │ ├─ _模块索引.md # 模块 MOC │ ├─ 核心模块.md │ ├─ 工具函数.md │ └─ ... ├─ 05-配置参考.md # 环境变量、配置项 ├─ 06-开发指南/ │ ├─ 本地开发.md │ ├─ 测试指南.md │ └─ 部署流程.md └─ _templates/ # Obsidian 模板 ├─ 新功能模板.md └─ Bug记录模板.md
📝 文档模板
项目概览模板 (MOC)
--- tags: [project, moc, {{项目类型}}] created: {{日期}} --- # {{项目名}} 知识库 > {{一句话描述}} ## 🚀 快速导航 - [[01-快速开始|快速开始]] - 5 分钟上手 - [[02-架构设计/整体架构|架构设计]] - 了解系统设计 - [[03-API文档/_API索引|API 文档]] - 接口参考 ## 📊 项目信息 | 属性 | 值 | |------|-----| | 语言 | {{主语言}} | | 框架 | {{框架}} | | 版本 | {{版本}} | | 仓库 | {{仓库地址}} | ## 🗂️ 目录结构
{{项目结构树}}
## 🔗 核心模块 {{模块链接列表}} ## 📅 最近更新 - {{更新记录}} --- *由 project-to-obsidian 自动生成*
API 文档模板
--- tags: [api, {{模块}}] endpoint: {{路径}} method: {{方法}} --- # {{API名称}} > {{描述}} ## 请求 ```http {{方法}} {{路径}}
参数
| 参数 | 类型 | 必填 | 说明 |
|---|---|---|---|
| {{参数表}} |
请求示例
{{请求示例}}
响应
成功响应
{{响应示例}}
相关
- [[{{相关API}}]]
- [[{{相关模块}}]]
### 模块说明模板 ```markdown --- tags: [module, {{标签}}] path: {{文件路径}} --- # {{模块名}} > {{模块描述}} ## 职责 {{职责说明}} ## 核心函数 ### `{{函数名}}` ```{{语言}} {{函数签名}}
参数: {{参数说明}}
返回: {{返回说明}}
示例:
{{使用示例}}
依赖关系
graph LR {{模块}} --> {{依赖1}} {{模块}} --> {{依赖2}}
相关模块
- [[{{相关模块1}}]]
- [[{{相关模块2}}]]
--- ## 🔧 输出选项 ### 选项 1: 输出到 Obsidian Vault (推荐)
如果检测到 Obsidian MCP 可用: ├─ 询问用户选择目标 vault ├─ 在 vault 中创建项目文件夹 ├─ 使用 obsidian_append_content 写入文件 └─ 完成后可直接使用 obsidian-helper 功能
### 选项 2: 创建本地文件夹
├─ 询问输出路径 ├─ 创建 {{项目名}}-knowledge-base/ 文件夹 ├─ 使用 Write 工具写入所有文件 └─ 提示用户在 Obsidian 中打开该文件夹
### 选项 3: 输出到项目 /docs
├─ 在项目目录创建 /docs/obsidian/ 文件夹 ├─ 写入所有文档 ├─ 添加 .gitignore 排除(可选) └─ 文档与代码同步版本控制
--- ## 🎯 使用示例 ### 示例 1: 完整转换
用户: /p2o /Users/jun/Projects/my-api
Claude:
- 扫描项目... 检测到 Node.js + Express 项目
- 分析代码... 找到 15 个 API 端点,8 个核心模块
- 询问:输出到哪里?
- [1] 当前 Obsidian vault (Projects/ 文件夹)
- [2] 新建文件夹
- [3] 项目内 /docs
- 用户选择 [1]
- 生成文档到 Obsidian vault
- 完成!生成了 23 个笔记文件
### 示例 2: 快速概览
用户: /p2o ~/code/rust-project --quick
Claude:
- 快速扫描项目结构
- 生成:
- 项目概览.md
- 目录结构.md
- 技术栈.md
- 输出 3 个文件到指定位置
### 示例 3: 只生成 API 文档
用户: /p2o ./backend --api
Claude:
- 扫描 API 路由文件
- 提取所有端点
- 生成 API 文档集合
- 输出到 Obsidian
--- ## 🔗 与其他工具集成 ### 与 obsidian-helper 集成 生成的知识库完全兼容 obsidian-helper:
/daily → 在日记中记录「今天研究了 [[my-api-知识库/03-API文档/用户认证|用户认证 API]]」
/capture API设计 发现了一个新的设计模式 → 自动链接到相关 API 文档
/review weekly → 回顾中包含项目相关笔记的修改
### 与 MCP 工具集成
生成后可使用 MCP 工具: ├─ obsidian_simple_search - 搜索项目文档 ├─ obsidian_patch_content - 更新文档 ├─ obsidian_get_file_contents - 读取文档 └─ obsidian_append_content - 添加新文档
--- ## ⚙️ 配置选项 在目标 vault 创建 `_config/project-to-obsidian.md` 自定义: ```markdown # Project to Obsidian 配置 ## 生成选项 - 生成 Mermaid 图表: true - 生成代码示例: true - 提取注释: true - 最大文件大小: 100KB ## 忽略规则 - 忽略文件夹: node_modules, .git, dist, build, __pycache__ - 忽略文件: *.min.js, *.map, *.lock ## 输出设置 - 默认输出位置: Projects/ - 文档语言: zh-CN - 链接样式: wiki-link
🚨 错误处理
| 情况 | 处理 |
|---|---|
| 项目路径不存在 | 提示用户检查路径 |
| 项目太大 (>1000 文件) | 建议使用 --quick 模式或指定子目录 |
| 无法识别项目类型 | 询问用户手动指定语言/框架 |
| MCP 未连接 | 自动切换到本地文件输出 |
| 写入失败 | 回滚并提示错误原因 |
📚 支持的项目类型
| 语言/框架 | 识别标志 | 特殊处理 |
|---|---|---|
| Node.js | package.json | 提取 scripts, dependencies |
| TypeScript | tsconfig.json | 提取类型定义 |
| Python | pyproject.toml, setup.py | 提取 docstrings |
| Go | go.mod | 提取包结构 |
| Rust | Cargo.toml | 提取 crate 结构 |
| Java | pom.xml, build.gradle | 提取类和接口 |
| React/Vue/Angular | 框架配置 | 提取组件结构 |
| Express/FastAPI/Gin | 路由文件 | 提取 API 端点 |
📎 快速参考
/p2o <路径> → 完整转换项目到 Obsidian /p2o <路径> --quick → 快速生成概览 /p2o <路径> --api → 只生成 API 文档 /p2o <路径> --arch → 只生成架构文档 /p2o <路径> -o <输出> → 指定输出位置
Project to Obsidian v1.0.0 - 让代码知识可视化