Claude Code 对话自动导入完全指南

本文面向:使用 Claude Code 的开发者,想了解 ChatCrystal 如何导入和处理对话数据。

预计阅读时间:8 分钟


Claude Code 的对话存在哪

Claude Code 把每轮对话保存为 JSONL 文件,存放在:

复制代码
~/.claude/projects/
├── c--Users-Project-MyApp/
│   ├── abc123.jsonl
│   ├── def456.jsonl
│   └── ...
├── c--Users-Project-AnotherApp/
│   └── ...
└── ...

每个子目录对应一个项目,目录名是项目路径的编码(/ 替换为 -)。每个 .jsonl 文件是一次对话,每行是一个 JSON 对象,包含一条消息。

导入时发生了什么

运行 crystal import 时,ChatCrystal 做了以下事情:

复制代码
扫描 ~/.claude/projects/**/*.jsonl
  → 逐行读取 JSONL
  → 过滤噪音消息
  → 清理系统标签
  → 提取 user / assistant 消息
  → 按项目分组
  → 写入 SQLite 数据库

噪音过滤

Claude Code 的 JSONL 里混着大量非对话内容,ChatCrystal 会自动过滤:

过滤的消息类型 说明
file-history-snapshot 文件历史快照
progress / agent_progress 进度信息
tool_use / tool_result 工具调用流式片段
thinking 思考过程流式片段
system 系统消息(api_error、compact_boundary 等)
流式 delta(无 uuid) 实时流式传输的中间状态

只保留 userassistant 类型的完整消息。

内容清理

Claude Code 的消息内容里有很多系统标签,ChatCrystal 会自动清除:

xml 复制代码
<!-- 这些会被删除 -->
<system-reminder>...</system-reminder>
<command-name>/help</command-name>
<command-message>...</command-message>
<command-args>...</command-args>
<local-command-stdout>...</local-command-stdout>
<local-command-caveat>...</local-command-caveat>

清理后只保留实际的对话内容。

项目名提取

目录名 c--Users-Project-ChatCrystal 会被解析为 ChatCrystal。规则是找到 Projectprojects 标记,取后面的部分。

自定义数据目录

如果你的 Claude Code 数据不在默认位置,可以通过环境变量指定:

bash 复制代码
CLAUDE_PROJECTS_DIR=/path/to/your/claude/projects crystal import

或在 ChatCrystal 设置页面修改 Claude Projects Dir 配置。

文件监听:自动导入

ChatCrystal 启动后会自动监听 Claude Code 数据目录。当你和 Claude Code 产生新对话时,ChatCrystal 会自动检测并导入,不需要手动执行 crystal import

监听逻辑:

  • 使用 chokidar 监听 ~/.claude/projects/**/*.jsonl
  • 新文件或文件变化时触发导入
  • 有防抖机制(debounce),避免频繁触发

手动导入 vs 自动导入

方式 命令 适用场景
手动 crystal import 首次导入、批量导入历史数据
自动 文件监听(默认开启) 日常使用,新对话自动同步

首次使用建议手动 crystal import 一次,把历史数据全部导入。之后文件监听会自动处理新增对话。

导入结果验证

bash 复制代码
crystal status

输出示例:

复制代码
ChatCrystal Status
  Server       : running
  Database     : connected
  Conversations: 147
  Notes        : 89
  Tags         : 23

如果 Conversations 数量为 0,说明没有检测到对话文件。检查:

  1. Claude Code 是否有历史对话:ls ~/.claude/projects/
  2. 目录下是否有 .jsonl 文件
  3. 如果用了自定义目录,确认 CLAUDE_PROJECTS_DIR 配置正确

常见问题

导入后看不到对话

确认导入时没有报错。运行 crystal import 查看输出:

复制代码
Scanning claude-code: found 0 conversations

如果是 0,检查 ~/.claude/projects/ 目录是否存在以及是否有 .jsonl 文件。

对话内容不完整

Claude Code 的 JSONL 是流式写入的,如果对话中途异常退出(比如 kill 进程),最后几条消息可能不完整。ChatCrystal 会跳过格式异常的行,不影响其他消息的导入。

导入速度

纯文本解析非常快,100 个对话文件通常在 1-2 秒内完成。慢的部分是后续的 LLM 摘要生成,不是导入本身。


项目地址:github.com/ZengLiangYi/ChatCrystal

相关推荐
计算机安禾2 分钟前
【数据库系统原理】第9篇:SQL的结构化思维:DDL、DML与DCL的职责分离
数据库·sql·oracle
计算机安禾6 分钟前
【数据库系统原理】第12篇:视图机制:外模式在SQL层级的逻辑数据独立性实现
数据库·sql·oracle
前进的李工10 分钟前
MySQL性能优化:索引与子查询实战技巧
数据库·sql·mysql·性能优化
疯狂成瘾者18 分钟前
API Key 生成和鉴权机制:从随机凭证生成到请求拦截校验
数据库·oracle
Volunteer Technology31 分钟前
SpringSecurity中的权限管理
java·数据库·servlet
段ヤシ.40 分钟前
回顾Java知识点,面试题汇总Day13:数据库MySQL(持续更新)
java·数据库·mysql
mN9B2uk171 小时前
在Qt中使用SQLite数据库
数据库·qt·sqlite
network_tester1 小时前
SENT/PSI5传感器TSN集成测试:打通传统传感与未来车载网络的“最后一公里”
数据库·网络协议·tcp/ip·自动驾驶·信息与通信·信号处理·tcpdump
桌面运维家1 小时前
校园机房vDisk IDV云桌面建设方案价格参考
linux·服务器·数据库
七牛云行业应用1 小时前
GitHub Copilot 2026年6月新计费实战:AI Credits怎么算、怎么省
人工智能·github·copilot