A plugin to sync your Get笔记 (Get Notes) content into Obsidian with incremental sync, auto-sync, and multiple visualization options.
一个将 Get笔记 的内容同步到 Obsidian 的插件。支持增量同步、自动同步和多种可视化方式。
source 字段,实现更专业的元数据管理<p> 标签结构,实施了健壮的节点遍历机制,彻底杜绝了元数据清理时意外"吞噬"正文导致的内容丢失问题\_ 和 \. 等杂音,完整保留方括号、星号、井号等对 Markdown 结构至关重要的转义<pre><code> 内的 HTML 实体解码逻辑,确保代码块中的尖括号、连接符等特殊符号能被正确转回 Markdown[[wiki-links]] 格式<mark> 为 Obsidian 的 ==高亮== 语法git clone https://github.com/springrain1/get-to-obsidian.git
cd get-to-obsidian
npm install
npx [email protected] install
⚠️ 必须安装 Playwright:本插件使用 Playwright 进行浏览器自动化,这是同步功能的核心依赖。
如果在中国大陆地区安装失败,可以使用镜像:
export PLAYWRIGHT_DOWNLOAD_HOST=https://npmmirror.com/mirrors/playwright/
npx [email protected] install
或者强制重新安装:
npx [email protected] install --force
npm run build
将以下文件复制到你的 Obsidian vault 的 .obsidian/plugins/get-importer/ 目录:
main.jsmanifest.jsonstyles.css或者使用部署脚本(需要先配置):
# 方式 1: 使用环境变量
export VAULT_PATH="/path/to/your/obsidian/vault"
./deploy.sh
# 方式 2: 创建本地部署脚本
cp deploy.sh deploy.local.sh
# 编辑 deploy.local.sh,设置 VAULT_PATH 为你的 vault 路径
./deploy.local.sh
设置 → 第三方插件 → 关闭安全模式已安装插件中找到 Get笔记 Importer 并启用⚠️ 注意:使用 BRAT 安装后,仍需手动安装 Playwright:
npx [email protected] install
Ctrl/Cmd + P → 输入 Get笔记
get)memos)get/memos/2024-01-15/ 目录下启动时自动同步
定时自动同步
查看同步状态
方式 1:自动导出导入
Ctrl/Cmd + P → Get笔记: 立即同步方式 2:手动导入 ZIP 文件
1. Moments 时间线
Get Moments.md 文件2. Canvas 画布
Get Canvas.canvas 文件插件支持按类型选择性导入附件,帮助你更好地控制 vault 的存储空间:
支持的附件类型:
配置方式:
智能链接处理:
示例:
# 只启用图片导入时
原始笔记: 和 [文档](files/doc.pdf)
导入结果: 和 文档
插件针对不同平台采用了优化的文件处理策略:
桌面端(Electron):
file.path)移动端或路径不可用时:
附件复制优化:
fs.copyFile 直接拷贝,零内存占用,最优性能adapter.writeBinary() API 限制技术说明:
decompress 库需要本地文件路径,无法直接处理浏览器 File 对象file.stream().getReader() + fs.createWriteStream()1. 双向链接支持
[[链接]] 格式2. 按日期合并笔记
[email protected]如果需要重新导入所有笔记:
get/memos/)⚠️ 警告:此操作会清除同步记录,可能导致重复导入。建议先备份重要数据。
同步后,你的 Obsidian vault 会生成以下结构:
你的 Vault/
├── get/ # 主文件夹(可自定义)
│ ├── memos/ # 笔记子目录
│ │ ├── 2024-01-15/ # 按日期分组
│ │ │ ├── memo@笔记标题_1.md
│ │ │ ├── memo@笔记标题_2.md
│ │ │ └── ...
│ │ └── ...
│ ├── get attachment/ # 附件目录(新版本结构)
│ │ ├── 2024-01-15/
│ │ │ ├── image1.jpg
│ │ │ ├── audio.m4a
│ │ │ └── ...
│ │ └── ...
│ ├── Get Moments.md # 时间线文件(可选)
│ └── Get Canvas.canvas # 画布文件(可选)
└── ...
# 克隆仓库
git clone https://github.com/springrain1/get-to-obsidian.git
cd get-to-obsidian
# 安装依赖
npm install
# 安装 Playwright
npx [email protected] install
# 开发模式(热重载)
npm run dev
# 构建生产版本
npm run build
# 代码检查
npm run lint
# 自动修复代码风格
npm run fix
get-to-obsidian/
├── lib/
│ ├── get/ # 核心功能
│ │ ├── auth.ts # 认证登录
│ │ ├── core.ts # 数据解析
│ │ ├── exporter.ts # 数据导出
│ │ ├── importer.ts # 数据导入
│ │ └── const.ts # 常量定义
│ ├── obIntegration/ # Obsidian 集成
│ │ ├── canvas.ts # Canvas 生成
│ │ └── moments.ts # Moments 生成
│ └── ui/ # 用户界面
│ ├── auth_ui.ts # 登录界面
│ ├── main_ui.ts # 主界面
│ ├── manualsync_ui.ts # 手动导入界面
│ └── ...
├── main.ts # 插件入口
├── manifest.json # 插件清单
├── styles.css # 样式文件
├── esbuild.config.mjs # 构建配置
├── package.json # 项目依赖
└── ...
1. 用户触发同步
↓
2. Playwright 打开浏览器登录 Get笔记
↓
3. 自动导出数据为 HTML 压缩包
↓
4. 解析 HTML,提取笔记内容
↓
5. 生成唯一 ID(时间戳 + 内容哈希)
↓
6. 过滤已同步的笔记(增量同步)
↓
7. 转换为 Markdown 格式
↓
8. 保存到 Obsidian vault
↓
9. 可选:生成 Moments 和 Canvas
↓
10. 更新同步记录
插件为每条笔记生成唯一 ID:
格式:${时间戳}_${内容哈希}_${出现次数}_${总数}
示例:2024-01-15T10:30:00_abc123_1_245
已同步的 ID 存储在插件设置中,每次同步只导入新 ID 的笔记。
编辑 lib/get/importer.ts - 控制 Markdown 输出格式和 frontmatter
lib/obIntegration/moments.ts - Moments 显示逻辑lib/obIntegration/canvas.ts - Canvas 布局和样式lib/ui/ 目录下的文件 - UI 组件styles.css - 样式修改编辑 lib/get/const.ts - 所有路径常量
# 更新版本号(会自动更新 manifest.json 和 versions.json)
npm run version
# 构建
npm run build
# 提交更改
git add .
git commit -m "Release version X.X.X"
git push
# 创建 GitHub Release
# 上传 main.js、manifest.json、styles.css
问题:Obsidian 提示插件加载失败
解决:
Ctrl/Cmd + Shift + I)问题:浏览器打开后无法完成登录
解决:
npx [email protected] install问题:点击同步后提示"新增 0 条笔记"
可能原因:
解决:
问题:开启可视化选项后,文件生成但内容为空
解决:
问题:笔记中的图片、音频等附件没有被导入
可能原因:
解决:
Ctrl/Cmd + Shift + I)检查具体错误查看导入统计: 同步完成后,控制台会显示详细的附件统计信息:
附件统计 - 总计: 45, 图片: 30, 音频: 10, 视频: 3, 文档: 2, 失败: 0
问题:导入大型 ZIP 文件时崩溃或提示内存不足
解决:
使用直接路径策略 - 桌面端优化策略(最佳)使用临时文件回退策略 - 真流式写入策略fs.copyFile,性能最优问题:npx playwright install 报错
解决:
# 方法 1: 使用指定版本
npx [email protected] install --force
# 方法 2: 清除缓存后重装
npm cache clean --force
npm install
npx [email protected] install
# 方法 3: 使用镜像(中国大陆)
export PLAYWRIGHT_DOWNLOAD_HOST=https://npmmirror.com/mirrors/playwright/
npx [email protected] install
如果从 1.x 版本升级到 2.0,附件路径结构已改变:
选项 A:完全重新导入(推荐)
get/memos/ 和 get picture/选项 B:保留现有笔记
欢迎任何形式的贡献!这是一个免费开源项目,希望能帮助更多使用 Get笔记 和 Obsidian 的朋友。
git checkout -b feature/AmazingFeaturegit commit -m 'Add some AmazingFeature'git push origin feature/AmazingFeaturenpm run lint 检查)如果你发现 bug 或有功能建议:
本项目采用 MIT License 开源许可证。
你可以自由地:
但需要:
如果这个插件对你有帮助,请给个 ⭐️ Star 支持一下!
本项目完全免费开源,欢迎自用和分享!
Made with ❤️ by Community