Skip to main content

把 Claude Code / GitHub Copilot 對話 session 變成 Obsidian 裡依語意主題分區、可翻找、可給 Claude compact 後回想的回顧筆記

Project description

session-to-obsidian

CI PyPI Python License: MIT

Turn a Claude Code or GitHub Copilot Chat session into an Obsidian note that is organized by topic, easy to browse, good for writing from, and useful as a memory layer your AI can recall after a context compaction.

繁體中文說明見 README.zh-TW.md.

Not a verbatim log dump. It splits one session into coherent topic threads (not time slices). Under each topic: what you asked + the assistant's full narrative + the tools/files/screenshots involved, with a table of contents on top — plus a cross-session INDEX.md.

Why

One AI coding session often does several unrelated things (fix a bug, tweak some UI, detour into something else). Later you want to find "how did I solve that thing" — and a timeline is useless, because what you remember is the topic, not the timestamp. This tool uses an LLM to cluster steps into topics so the note is organized the way you remember it.

The first audience is the author's own future self (a tool you keep using); open source is a bonus.

Install

pipx install session-to-obsidian

Topic clustering calls your local claude CLI (Claude Code) in headless mode — no API key, uses your existing subscription. No Claude Code? It still works, clustering just degrades to time-slicing (see below).

Usage

# A Claude Code session (jsonl lives in ~/.claude/projects/<proj>/<uuid>.jsonl)
s2o import ~/.claude/projects/myproj/abc123.jsonl --vault ~/Obsidian

# A Copilot Chat session (VS Code's chatSessions/<uuid>.jsonl append-log)
s2o import "~/…/workspaceStorage/<hash>/chatSessions/<uuid>.jsonl" --vault ~/Obsidian

# Output language (labels + generated titles). Default: en
s2o import <file> --vault ~/Obsidian --lang zh-TW

# No LLM — pure time-segmentation (offline / no Claude Code)
s2o import <file> --vault ~/Obsidian --cluster time

# Rebuild the index only
s2o index --vault ~/Obsidian

Source (Claude native / Copilot append-log) is auto-detected. Output goes to <vault>/90-Meta/sessions/<date>-<source>-<title>/ with a .md (recap) and .canvas (topic-grouped node graph). Set S2O_VAULT to skip --vault; S2O_LANG to set a default language. Re-importing the same session replaces the previous note (deduped by an originSessionId stored in frontmatter).

How it works

detect source → adapter restores steps → extract "ask + files + first-line gist"
   → cluster (LLM) → render .md/.canvas → update INDEX.md

Clustering only feeds the LLM the ask list + each step's touched filenames + the assistant's first line (never the full transcript), so token use is bounded. Compound asks go to their dominant topic; topics may be non-contiguous in time; each step keeps its original number.

Limitations

  • Topic clustering needs the local claude CLI (Claude Code). Without it, use --cluster time.
  • Images are not extracted by default (--images to enable). By Obsidian convention images live under _attachments/ (gitignore them; sync via Syncthing to avoid bloating git).
  • Topic names / titles are LLM-generated; quality depends on the model. Re-run a single session to regenerate.

Development

pip install pytest -e .
pytest

License

MIT — see LICENSE.

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

session_to_obsidian-0.1.0.tar.gz (26.6 kB view details)

Uploaded Source

Built Distribution

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

session_to_obsidian-0.1.0-py3-none-any.whl (22.6 kB view details)

Uploaded Python 3

File details

Details for the file session_to_obsidian-0.1.0.tar.gz.

File metadata

  • Download URL: session_to_obsidian-0.1.0.tar.gz
  • Upload date:
  • Size: 26.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for session_to_obsidian-0.1.0.tar.gz
Algorithm Hash digest
SHA256 b24f68825b288e128bd7f7472b38dbd71ecc1439d213c2aade2fe7a2f8af9598
MD5 a316bfdd4035c58858942b53f4037c74
BLAKE2b-256 a92a5ed9eac1650a3ae0fbcd4382630093c4865dbf341f471485131687cdc9a9

See more details on using hashes here.

Provenance

The following attestation bundles were made for session_to_obsidian-0.1.0.tar.gz:

Publisher: release.yml on timo9378/session-to-obsidian

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

File details

Details for the file session_to_obsidian-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for session_to_obsidian-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1205f9cdb42ca3fbf0379a32d9fca7f599cd9f69498d751b0e5d061a523970a8
MD5 cd5e1e894df3e731acfbfdcd4fe3e1bd
BLAKE2b-256 091b9f60ddc5702070bc53c2830cbaba7a928ea2470c063b58b842b6ceacb998

See more details on using hashes here.

Provenance

The following attestation bundles were made for session_to_obsidian-0.1.0-py3-none-any.whl:

Publisher: release.yml on timo9378/session-to-obsidian

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