# Sessions 命令 管理 Claude Code 会话历史 - 列出、加载、设置别名和编辑存储在 `~/.claude/sessions/` 中的会话。 ## 用法 `/sessions [list|load|alias|info|help] [options]` ## 操作 ### 列出会话 显示所有会话及其元数据,支持筛选和分页。 ```bash /sessions # List all sessions (default) /sessions list # Same as above /sessions list --limit 10 # Show 10 sessions /sessions list --date 2026-02-01 # Filter by date /sessions list --search abc # Search by session ID ``` **脚本:** ```bash node -e " const sm = require('./scripts/lib/session-manager'); const aa = require('./scripts/lib/session-aliases'); const result = sm.getAllSessions({ limit: 20 }); const aliases = aa.listAliases(); const aliasMap = {}; for (const a of aliases) aliasMap[a.sessionPath] = a.name; console.log('Sessions (showing ' + result.sessions.length + ' of ' + result.total + '):'); console.log(''); console.log('ID Date Time Size Lines Alias'); console.log('────────────────────────────────────────────────────'); for (const s of result.sessions) { const alias = aliasMap[s.filename] || ''; const size = sm.getSessionSize(s.sessionPath); const stats = sm.getSessionStats(s.sessionPath); const id = s.shortId === 'no-id' ? '(none)' : s.shortId.slice(0, 8); const time = s.modifiedTime.toTimeString().slice(0, 5); console.log(id.padEnd(8) + ' ' + s.date + ' ' + time + ' ' + size.padEnd(7) + ' ' + String(stats.lineCount).padEnd(5) + ' ' + alias); } " ``` ### 加载会话 加载并显示会话内容(通过 ID 或别名)。 ```bash /sessions load # Load session /sessions load 2026-02-01 # By date (for no-id sessions) /sessions load a1b2c3d4 # By short ID /sessions load my-alias # By alias name ``` **脚本:** ```bash node -e " const sm = require('./scripts/lib/session-manager'); const aa = require('./scripts/lib/session-aliases'); const id = process.argv[1]; // First try to resolve as alias const resolved = aa.resolveAlias(id); const sessionId = resolved ? resolved.sessionPath : id; const session = sm.getSessionById(sessionId, true); if (!session) { console.log('Session not found: ' + id); process.exit(1); } const stats = sm.getSessionStats(session.sessionPath); const size = sm.getSessionSize(session.sessionPath); const aliases = aa.getAliasesForSession(session.filename); console.log('Session: ' + session.filename); console.log('Path: ~/.claude/sessions/' + session.filename); console.log(''); console.log('Statistics:'); console.log(' Lines: ' + stats.lineCount); console.log(' Total items: ' + stats.totalItems); console.log(' Completed: ' + stats.completedItems); console.log(' In progress: ' + stats.inProgressItems); console.log(' Size: ' + size); console.log(''); if (aliases.length > 0) { console.log('Aliases: ' + aliases.map(a => a.name).join(', ')); console.log(''); } if (session.metadata.title) { console.log('Title: ' + session.metadata.title); console.log(''); } if (session.metadata.started) { console.log('Started: ' + session.metadata.started); } if (session.metadata.lastUpdated) { console.log('Last Updated: ' + session.metadata.lastUpdated); } " "$ARGUMENTS" ``` ### 创建别名 为会话创建一个易记的别名。 ```bash /sessions alias # Create alias /sessions alias 2026-02-01 today-work # Create alias named "today-work" ``` **脚本:** ```bash node -e " const sm = require('./scripts/lib/session-manager'); const aa = require('./scripts/lib/session-aliases'); const sessionId = process.argv[1]; const aliasName = process.argv[2]; if (!sessionId || !aliasName) { console.log('Usage: /sessions alias '); process.exit(1); } // Get session filename const session = sm.getSessionById(sessionId); if (!session) { console.log('Session not found: ' + sessionId); process.exit(1); } const result = aa.setAlias(aliasName, session.filename); if (result.success) { console.log('✓ Alias created: ' + aliasName + ' → ' + session.filename); } else { console.log('✗ Error: ' + result.error); process.exit(1); } " "$ARGUMENTS" ``` ### 移除别名 删除现有的别名。 ```bash /sessions alias --remove # Remove alias /sessions unalias # Same as above ``` **脚本:** ```bash node -e " const aa = require('./scripts/lib/session-aliases'); const aliasName = process.argv[1]; if (!aliasName) { console.log('Usage: /sessions alias --remove '); process.exit(1); } const result = aa.deleteAlias(aliasName); if (result.success) { console.log('✓ Alias removed: ' + aliasName); } else { console.log('✗ Error: ' + result.error); process.exit(1); } " "$ARGUMENTS" ``` ### 会话信息 显示会话的详细信息。 ```bash /sessions info # Show session details ``` **脚本:** ```bash node -e " const sm = require('./scripts/lib/session-manager'); const aa = require('./scripts/lib/session-aliases'); const id = process.argv[1]; const resolved = aa.resolveAlias(id); const sessionId = resolved ? resolved.sessionPath : id; const session = sm.getSessionById(sessionId, true); if (!session) { console.log('Session not found: ' + id); process.exit(1); } const stats = sm.getSessionStats(session.sessionPath); const size = sm.getSessionSize(session.sessionPath); const aliases = aa.getAliasesForSession(session.filename); console.log('Session Information'); console.log('════════════════════'); console.log('ID: ' + (session.shortId === 'no-id' ? '(none)' : session.shortId)); console.log('Filename: ' + session.filename); console.log('Date: ' + session.date); console.log('Modified: ' + session.modifiedTime.toISOString().slice(0, 19).replace('T', ' ')); console.log(''); console.log('Content:'); console.log(' Lines: ' + stats.lineCount); console.log(' Total items: ' + stats.totalItems); console.log(' Completed: ' + stats.completedItems); console.log(' In progress: ' + stats.inProgressItems); console.log(' Size: ' + size); if (aliases.length > 0) { console.log('Aliases: ' + aliases.map(a => a.name).join(', ')); } " "$ARGUMENTS" ``` ### 列出别名 显示所有会话别名。 ```bash /sessions aliases # List all aliases ``` **脚本:** ```bash node -e " const aa = require('./scripts/lib/session-aliases'); const aliases = aa.listAliases(); console.log('Session Aliases (' + aliases.length + '):'); console.log(''); if (aliases.length === 0) { console.log('No aliases found.'); } else { console.log('Name Session File Title'); console.log('─────────────────────────────────────────────────────────────'); for (const a of aliases) { const name = a.name.padEnd(12); const file = (a.sessionPath.length > 30 ? a.sessionPath.slice(0, 27) + '...' : a.sessionPath).padEnd(30); const title = a.title || ''; console.log(name + ' ' + file + ' ' + title); } } " ``` ## 参数 $ARGUMENTS: * `list [options]` - 列出会话 * `--limit ` - 最大显示会话数(默认:50) * `--date ` - 按日期筛选 * `--search ` - 在会话 ID 中搜索 * `load ` - 加载会话内容 * `alias ` - 为会话创建别名 * `alias --remove ` - 移除别名 * `unalias ` - 与 `--remove` 相同 * `info ` - 显示会话统计信息 * `aliases` - 列出所有别名 * `help` - 显示此帮助信息 ## 示例 ```bash # List all sessions /sessions list # Create an alias for today's session /sessions alias 2026-02-01 today # Load session by alias /sessions load today # Show session info /sessions info today # Remove alias /sessions alias --remove today # List all aliases /sessions aliases ``` ## 备注 * 会话以 Markdown 文件形式存储在 `~/.claude/sessions/` * 别名存储在 `~/.claude/session-aliases.json` * 会话 ID 可以缩短(通常前 4-8 个字符就足够唯一) * 为经常引用的会话使用别名