Convert Claude Code session files to HTML transcripts
Project description
claude-code-transcripts
Convert Claude Code session files (JSON or JSONL) to clean, mobile-friendly HTML pages with pagination.
Example transcript produced using this tool.
Read A new way to extract detailed transcripts from Claude Code for background on this project.
Installation
Install this tool using uv:
uv tool install claude-code-transcripts
Or run it without installing:
uvx claude-code-transcripts --help
Usage
This tool converts Claude Code session files into browseable multi-page HTML transcripts.
There are four commands available:
local(default) - select from local Claude Code sessions stored in~/.claude/projectsweb- select from web sessions via the Claude APIjson- convert a specific JSON or JSONL session fileall- convert all local sessions to a browsable HTML archive
The quickest way to view a recent local session:
claude-code-transcripts
This shows an interactive picker to select a session, generates HTML, and opens it in your default browser.
Output options
All commands support these options:
-o, --output DIRECTORY- output directory (default: writes to temp dir and opens browser)-a, --output-auto- auto-name output subdirectory based on session ID or filename--repo OWNER/NAME- GitHub repo for commit links (auto-detected if not specified). Forwebcommand, also filters the session list.--open- open the generatedindex.htmlin your default browser (default if no-ospecified)--gist- upload the generated HTML files to a GitHub Gist and output a preview URL--json- include the original session file in the output directory
The generated output includes:
index.html- an index page with a timeline of prompts and commitspage-001.html,page-002.html, etc. - paginated transcript pages
Local sessions
Local Claude Code sessions are stored as JSONL files in ~/.claude/projects. Run with no arguments to select from recent sessions:
claude-code-transcripts
# or explicitly:
claude-code-transcripts local
Use --limit to control how many sessions are shown (default: 10):
claude-code-transcripts local --limit 20
Web sessions
Import sessions directly from the Claude API:
# Interactive session picker
claude-code-transcripts web
# Import a specific session by ID
claude-code-transcripts web SESSION_ID
# Import and publish to gist
claude-code-transcripts web SESSION_ID --gist
The session picker displays sessions grouped by their associated GitHub repository:
simonw/datasette 2025-01-15T10:30:00 Fix the bug in query parser
simonw/llm 2025-01-14T09:00:00 Add streaming support
(no repo) 2025-01-13T14:22:00 General coding session
Use --repo to filter the session list to a specific repository:
claude-code-transcripts web --repo simonw/datasette
On macOS, API credentials are automatically retrieved from your keychain (requires being logged into Claude Code). On other platforms, provide --token and --org-uuid manually.
Publishing to GitHub Gist
Use the --gist option to automatically upload your transcript to a GitHub Gist and get a shareable preview URL:
claude-code-transcripts --gist
claude-code-transcripts web --gist
claude-code-transcripts json session.json --gist
This will output something like:
Gist: https://gist.github.com/username/abc123def456
Preview: https://gisthost.github.io/?abc123def456/index.html
Files: /var/folders/.../session-id
The preview URL uses gisthost.github.io to render your HTML gist. The tool automatically injects JavaScript to fix relative links when served through gisthost.
Combine with -o to keep a local copy:
claude-code-transcripts json session.json -o ./my-transcript --gist
Requirements: The --gist option requires the GitHub CLI (gh) to be installed and authenticated (gh auth login).
Auto-naming output directories
Use -a/--output-auto to automatically create a subdirectory named after the session:
# Creates ./session_ABC123/ subdirectory
claude-code-transcripts web SESSION_ABC123 -a
# Creates ./transcripts/session_ABC123/ subdirectory
claude-code-transcripts web SESSION_ABC123 -o ./transcripts -a
Including the source file
Use the --json option to include the original session file in the output directory:
claude-code-transcripts json session.json -o ./my-transcript --json
This will output:
JSON: ./my-transcript/session_ABC.json (245.3 KB)
This is useful for archiving the source data alongside the HTML output.
Converting from JSON/JSONL files
Convert a specific session file directly:
claude-code-transcripts json session.json -o output-directory/
claude-code-transcripts json session.jsonl --open
This works with both JSONL files in the ~/.claude/projects/ folder and JSON session files extracted from Claude Code for web.
The json command can take a URL to a JSON or JSONL file as an alternative to a path on disk.
Converting all sessions
Convert all your local Claude Code sessions to a browsable HTML archive:
claude-code-transcripts all
This creates a directory structure with:
- A master index listing all projects
- Per-project pages listing sessions
- Individual session transcripts
Options:
-s, --source DIRECTORY- source directory (default:~/.claude/projects)-o, --output DIRECTORY- output directory (default:./claude-archive)--include-agents- include agent session files (excluded by default)--dry-run- show what would be converted without creating files--open- open the generated archive in your default browser-q, --quiet- suppress all output except errors
Examples:
# Preview what would be converted
claude-code-transcripts all --dry-run
# Convert all sessions and open in browser
claude-code-transcripts all --open
# Convert to a specific directory
claude-code-transcripts all -o ./my-archive
# Include agent sessions
claude-code-transcripts all --include-agents
Development
To contribute to this tool, first checkout the code. You can run the tests using uv run:
cd claude-code-transcripts
uv run pytest
And run your local development copy of the tool like this:
uv run claude-code-transcripts --help
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file claude_code_transcripts-0.6.tar.gz.
File metadata
- Download URL: claude_code_transcripts-0.6.tar.gz
- Upload date:
- Size: 29.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c4cf35cd7f02bf6b71cb577c0a39ad25a184eeaf13ec6a2c8d6cdc2900324390
|
|
| MD5 |
556a8c599f5821a5cc5a73020e7202e8
|
|
| BLAKE2b-256 |
485e28056099926dcf7432d9274865fca074736522ff6ad1f1a59312dcd0bb69
|
Provenance
The following attestation bundles were made for claude_code_transcripts-0.6.tar.gz:
Publisher:
publish.yml on simonw/claude-code-transcripts
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
claude_code_transcripts-0.6.tar.gz -
Subject digest:
c4cf35cd7f02bf6b71cb577c0a39ad25a184eeaf13ec6a2c8d6cdc2900324390 - Sigstore transparency entry: 851516806
- Sigstore integration time:
-
Permalink:
simonw/claude-code-transcripts@cad133d9132a6255d8e948acfdaf5c8273bbff5f -
Branch / Tag:
refs/tags/0.6 - Owner: https://github.com/simonw
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@cad133d9132a6255d8e948acfdaf5c8273bbff5f -
Trigger Event:
release
-
Statement type:
File details
Details for the file claude_code_transcripts-0.6-py3-none-any.whl.
File metadata
- Download URL: claude_code_transcripts-0.6-py3-none-any.whl
- Upload date:
- Size: 32.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b0d5afbd0355ff7eefcfd64cb9f248d443d6d9899d0997d6fec4256b4dcb9a19
|
|
| MD5 |
53e124a2f4d76313daf54e1fb7e3cfd5
|
|
| BLAKE2b-256 |
2fb94422e5c8d40988810721a6fa6e48139b242652319c458f1f76408ef3cf54
|
Provenance
The following attestation bundles were made for claude_code_transcripts-0.6-py3-none-any.whl:
Publisher:
publish.yml on simonw/claude-code-transcripts
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
claude_code_transcripts-0.6-py3-none-any.whl -
Subject digest:
b0d5afbd0355ff7eefcfd64cb9f248d443d6d9899d0997d6fec4256b4dcb9a19 - Sigstore transparency entry: 851516843
- Sigstore integration time:
-
Permalink:
simonw/claude-code-transcripts@cad133d9132a6255d8e948acfdaf5c8273bbff5f -
Branch / Tag:
refs/tags/0.6 - Owner: https://github.com/simonw
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@cad133d9132a6255d8e948acfdaf5c8273bbff5f -
Trigger Event:
release
-
Statement type: