Skip to main content

Share-conscious HTML exporter for AI coding-assistant conversations (Claude and Codex).

Project description

chat2html

Share-conscious HTML exporter for AI coding-assistant conversations (Claude and Codex).

Why chat2html?

  • Four formats, one tool — Auto-detects Claude Code JSONL, claude.ai exports, claude-chat-exporter Markdown, and OpenAI Codex CLI JSONL.
  • Safer sharing defaults — Tool results are omitted and OAuth URLs (with state, code, token, callback paths) are redacted by default. Use --full only when you need the full picture for yourself.
  • Self-contained output — One HTML file with light/dark themes, syntax highlighting, and collapsible thinking blocks and long pastes.
  • Zero installuvx chat2html session.jsonl.

Supported input formats (auto-detected)

  1. claude.ai export (conversations.json / .jsonl)

    • Downloadable from Settings → Privacy → Export data (inside the ZIP).
    • Contains multiple conversations — pick them by listing, searching, or index.
  2. Claude Code session (~/.claude/projects/<proj>/*.jsonl)

    • Line-based logs with type / uuid / sessionId.
    • Renders tool-use history (Bash / Read / Edit / Agent, etc.).
    • thinking blocks and long tool_result outputs are collapsed into <details>.
  3. claude-chat-exporter.js Markdown (.md)

  4. OpenAI Codex CLI session (~/.codex/sessions/*.jsonl)

    • Line-based logs with top-level {timestamp, type, payload}.
    • Renders user / assistant text, function_call + function_call_output pairs (e.g. exec_command), and custom_tool_call (e.g. apply_patch).
    • Encrypted reasoning is omitted; visible reasoning.summary is rendered as a thinking block.

Quickstart

Run directly from PyPI with uv — no install required:

uvx chat2html session.jsonl

The examples below use chat2html as shorthand for the command above.

Usage

# Auto-detect format (Claude Code JSONL / Markdown)
chat2html session.jsonl
chat2html conversation.md
chat2html session.jsonl -o out.html

# claude.ai export: list conversations
chat2html conversations.json

# claude.ai export: search by title
chat2html conversations.json -s "API"

# claude.ai export: convert by index
chat2html conversations.json -i 0,3,7 -d out/

# claude.ai export: convert all
chat2html conversations.json --all -d out/

# Batch multiple files (Markdown / Claude Code JSONL)
chat2html a.md b.jsonl -d out/

# Directory: pick logs interactively from a TUI list
chat2html ~/.claude/projects/myproj -d out/

# Directory: convert everything underneath without the picker
chat2html ~/.codex/sessions/2026/04 --all -d out/

Directory mode (TUI picker)

chat2html directory mode TUI picker demo

Pass a directory and chat2html will walk it for .md / .jsonl files, drop anything that isn't a supported chat log, and show a multi-select list (↑↓ to move, Space to toggle, Enter to confirm, q / Esc to quit). Entries are sorted newest-first by mtime, with a one-line preview of the first user message (housekeeping slash-commands like /clear are skipped so they don't become the preview text). Combine with --all to skip the picker and convert every log under the directory.

Two safety caps keep the picker manageable when pointed at a deep tree like ~/.claude or ~/.codex:

  • --depth N — max recursion depth from the given root (0 = root only, default 5).
  • --max-files N — cap the list at the N most-recent files (0 = no cap, default 200). When entries are dropped, a notice is printed to stderr.

Options

Option Description
-o, --output Output file path (single conversation only).
-d, --outdir Output directory.
-s, --search Search conversations by title (claude.ai export).
-i, --index Comma-separated indices to convert (claude.ai export, e.g. 0,2,5).
--all Convert all conversations (claude.ai export) or every log under a directory (directory mode).
--depth N Directory mode: max recursion depth from the given root (0 = root only, default: 5).
--max-files N Directory mode: cap the picker list at the N most-recent files (0 = no cap, default: 200).
--lang {ja,en} Output language (default: ja).
--full Show full tool input/output. By default, tool_result is omitted and tool_use only shows description-like fields for safer sharing. OAuth-related URLs are always masked, even with --full.

⚠️ What chat2html does NOT protect against

chat2html redacts OAuth URLs and omits tool results by default, but it is not a general-purpose secret scrubber. Before sharing any output, you should still review it for:

  • API keys and tokens (e.g., sk-ant-..., ghp_...) that may appear in tool inputs or assistant text
  • Personal file paths (/Users/yourname/..., C:\Users\...)
  • Internal hostnames, repository names, or IP addresses
  • PII in pasted content (emails, phone numbers, etc.)
  • Long pastes are collapsed into <details> but still present in the HTML source — they're hidden visually, not removed.

If you need stronger guarantees, consider running a secret scanner (e.g., gitleaks, trufflehog) on the output before sharing.

Extra safety: scan the output before sharing

chat2html does not detect arbitrary secrets like API keys or tokens embedded in conversation content. If you're sharing with a wide audience, pipe the output through a dedicated secret scanner:

Both are open-source CLIs available via Homebrew and most package managers.

Development

uv sync --all-groups   # install runtime + dev dependencies
uv run pytest          # run the test suite
uv run ruff check .    # lint

CI runs the same ruff check + pytest on every push and PR (see .github/workflows/ci.yml).

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

chat2html-0.2.0rc1.tar.gz (29.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

chat2html-0.2.0rc1-py3-none-any.whl (36.0 kB view details)

Uploaded Python 3

File details

Details for the file chat2html-0.2.0rc1.tar.gz.

File metadata

  • Download URL: chat2html-0.2.0rc1.tar.gz
  • Upload date:
  • Size: 29.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for chat2html-0.2.0rc1.tar.gz
Algorithm Hash digest
SHA256 d93ed52e5e80dbfd3015612867d080bdea553ac16a31d5a80ff2833aef702c0f
MD5 aa1a764469fe778cbba67aba64d46e98
BLAKE2b-256 fa6343a09276288bc6bcde88fed67cc34c8c0ab2ece7bf834ffc2a624b3245aa

See more details on using hashes here.

Provenance

The following attestation bundles were made for chat2html-0.2.0rc1.tar.gz:

Publisher: release.yml on chezou/chat2html

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file chat2html-0.2.0rc1-py3-none-any.whl.

File metadata

  • Download URL: chat2html-0.2.0rc1-py3-none-any.whl
  • Upload date:
  • Size: 36.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for chat2html-0.2.0rc1-py3-none-any.whl
Algorithm Hash digest
SHA256 c89345c87c3a99ba1e77d3efae1980169fd0704aae6c389283f115c9c1f63a30
MD5 0c9d134160a52ef017a64d0724cb6f61
BLAKE2b-256 169c270f9d4df45992a79bc95a0f40306680ab5266df226f2227cde53f2b7e87

See more details on using hashes here.

Provenance

The following attestation bundles were made for chat2html-0.2.0rc1-py3-none-any.whl:

Publisher: release.yml on chezou/chat2html

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page