把 Claude Code / GitHub Copilot 對話 session 變成 Obsidian 裡依語意主題分區、可翻找、可給 Claude compact 後回想的回顧筆記
Project description
session-to-obsidian
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
claudeCLI (Claude Code). Without it, use--cluster time. - Images are not extracted by default (
--imagesto 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
Release history Release notifications | RSS feed
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 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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b24f68825b288e128bd7f7472b38dbd71ecc1439d213c2aade2fe7a2f8af9598
|
|
| MD5 |
a316bfdd4035c58858942b53f4037c74
|
|
| BLAKE2b-256 |
a92a5ed9eac1650a3ae0fbcd4382630093c4865dbf341f471485131687cdc9a9
|
Provenance
The following attestation bundles were made for session_to_obsidian-0.1.0.tar.gz:
Publisher:
release.yml on timo9378/session-to-obsidian
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
session_to_obsidian-0.1.0.tar.gz -
Subject digest:
b24f68825b288e128bd7f7472b38dbd71ecc1439d213c2aade2fe7a2f8af9598 - Sigstore transparency entry: 1864695031
- Sigstore integration time:
-
Permalink:
timo9378/session-to-obsidian@b78354aafe92e10d1bb7d163b07ba384d707ab98 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/timo9378
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@b78354aafe92e10d1bb7d163b07ba384d707ab98 -
Trigger Event:
push
-
Statement type:
File details
Details for the file session_to_obsidian-0.1.0-py3-none-any.whl.
File metadata
- Download URL: session_to_obsidian-0.1.0-py3-none-any.whl
- Upload date:
- Size: 22.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1205f9cdb42ca3fbf0379a32d9fca7f599cd9f69498d751b0e5d061a523970a8
|
|
| MD5 |
cd5e1e894df3e731acfbfdcd4fe3e1bd
|
|
| BLAKE2b-256 |
091b9f60ddc5702070bc53c2830cbaba7a928ea2470c063b58b842b6ceacb998
|
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
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
session_to_obsidian-0.1.0-py3-none-any.whl -
Subject digest:
1205f9cdb42ca3fbf0379a32d9fca7f599cd9f69498d751b0e5d061a523970a8 - Sigstore transparency entry: 1864695036
- Sigstore integration time:
-
Permalink:
timo9378/session-to-obsidian@b78354aafe92e10d1bb7d163b07ba384d707ab98 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/timo9378
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@b78354aafe92e10d1bb7d163b07ba384d707ab98 -
Trigger Event:
push
-
Statement type: