Skip to main content

Keyboard-first terminal UI for arXiv digest triage and live arXiv search

Project description

arXiv Subscription Viewer

arXiv Subscription Viewer

Triage arXiv papers from your terminal.
History mode or live API search · keyboard-first review · optional citation and LLM enrichment

Screenshot

CI/CD PyPI version Python versions License: MIT

🚀 Getting Started

Pick the entry path that matches how you already follow papers:

  • history/ workflow: review local daily digests with persistent date navigation, bookmarks, notes, and collections.
  • Live arXiv search: start directly from the API when you want the newest matching papers without preparing local files first.

Requires Python 3.13+.

Install

python3.13 --version

uv tool install arxiv-subscription-viewer
# or: python3.13 -m pip install --user arxiv-subscription-viewer

# Optional faster fuzzy matching
uv tool install "arxiv-subscription-viewer[fuzzy]"

First Run

arxiv-viewer doctor

# Start from live arXiv results
arxiv-viewer search --category cs.AI

# Or review a local history/ archive from its parent directory
arxiv-viewer browse

Press ? in-app for help and Ctrl+p for the command palette.

Typical Flow

  1. Install the CLI and run arxiv-viewer doctor.
  2. Scan papers with arxiv-viewer search ... or arxiv-viewer browse from a history/ archive.
  3. Enrich promising papers with Semantic Scholar (e/Ctrl+e), HuggingFace (Ctrl+h), version checks (V), or LLM summaries (Ctrl+s).
  4. Organize the queue with read state, stars, tags, notes, bookmarks, marks, collections, and spaced-review scheduling.
  5. Export selected papers or collections as BibTeX, RIS, CSV, Markdown, or PDFs.
  6. Configure defaults, API keys, export paths, and themes in config.json when the built-in defaults stop being enough.

Common Commands

# Search by topic
arxiv-viewer search --query "diffusion transformer" --field title

# Paginate through results (instead of collecting the newest day)
arxiv-viewer search --query "attention" --mode page --max-results 100

# Generate a cron-friendly Markdown digest
arxiv-viewer digest --category cs.AI --period weekly --output digest.md

# Open the same digest pipeline as an interactive inbox
arxiv-viewer digest --category cs.AI --period weekly --tui

# List local history dates
arxiv-viewer dates

# Inspect or clear local caches
arxiv-viewer cache-info
arxiv-viewer cache-clear --semantic --yes

# Show version
arxiv-viewer --version

# Print config file path
arxiv-viewer config-path

# Print key bindings (supports --format table|json|markdown, --tier core|standard|power|all)
arxiv-viewer keybindings

# Module entrypoint, equivalent to arxiv-viewer
python -m arxiv_browser --version

history/ setup details live in docs/history-mode.md.

Global options: --version · --debug (log to file) · --ascii (ASCII-only icons) · --color auto|always|never · --no-color · --theme NAME (built-in or custom_themes entry)

Debug log paths: ~/.config/arxiv-browser/debug.log (Linux) · ~/Library/Application Support/arxiv-browser/debug.log (macOS) · %APPDATA%/arxiv-browser/debug.log (Windows)

🧭 Choose A Workflow

history/ archive

Run the viewer from the directory that contains your history/ folder:

mkdir -p ~/research/arxiv/history
cd ~/research/arxiv
# Save a digest as history/2026-02-13.txt
arxiv-viewer

This path is best when you review daily digests in order and want persistent local state.

Live arXiv search

Use the API-first path when you want to start from current arXiv results:

arxiv-viewer search --category cs.AI
arxiv-viewer search --query "diffusion transformer" --field title

If something looks off, run arxiv-viewer doctor to check config, history discovery, CLI setup, and environment assumptions.

✨ Highlights

Feature Key
🔍 Fuzzy search with filters (cat:cs.AI, tag:, unread, starred) /
Quick triage — review visible unread papers one at a time T
📈 Trend Radar & author profiles — local history trends and exact author tracking Ctrl+p
🤖 AI summaries, chat, comparison, paper remix & auto-tag via any LLM CLI (Claude, Copilot, llm, …) Ctrl+s / C / Ctrl+v / Ctrl+p / Ctrl+g
📊 Citation graph and recommendations via Semantic Scholar G / R
🔥 HuggingFace trending — upvotes, keywords, GitHub links Ctrl+h
🧭 Smart Reading Queue — priority sort from relevance, watch matches, recency, HF, and S2 signals s
🧪 Local triage model — sklearn buckets for likely stars, unsure papers, and likely skips Ctrl+p
📨 Markdown digests & inboxes — cron-friendly briefs or interactive digest review arxiv-viewer digest / --tui
🏷️ Tags, notes, stars — organize your reading t / n / x
📁 Collections — curate reading lists Ctrl+k
📥 Export — BibTeX, Markdown, RIS, CSV, PDF download/preview E / d / F
🖼️ HTML figure preview — render the first arXiv HTML figure in-terminal I
🔊 Audio abstract reading — read the current abstract aloud with system TTS y
🎯 Relevance scoring — LLM scores papers against your interests L
📅 History mode — navigate daily email digests with [ / ]
⌨️ Command palette — quick access to all commands Ctrl+p
🎨 11 themes — Monokai, Catppuccin Mocha, Solarized Dark/Light, High Contrast, Dracula, Nord, Gruvbox Dark, Tokyo Night, Everforest Dark, GitHub Light Ctrl+t

Ctrl+p opens the command palette. Trend Radar, author profiles, the local triage model, paper remix/debate, and other power features are reached through it rather than via a dedicated key.

⌨️ Key Bindings

Key Action Key Action
/ Search o Open in browser
A Search arXiv API P Open PDF
j / k Navigate d Download PDF
Space Select F Preview PDF
s Cycle sort I Preview first figure
r Toggle read E Export menu
x Toggle star c Copy to clipboard
T Quick triage Ctrl+s AI summary
n Notes Ctrl+k Collections
Ctrl+v Compare papers C Chat with paper
p Abstract preview y Read abstract aloud
z Compact list (titles only) v Detail mode
Alt+Left / Alt+Right Resize list/details Alt+0 Reset pane sizes
L Relevance score t Tags
Ctrl+p Command palette V Check versions
Ctrl+g Auto-tag (LLM) Ctrl+b Save bookmark
G Citation graph m / ' Set / jump to mark
R Similar papers Ctrl+l Edit interests
1-9 Jump to bookmark Ctrl+d Detail pane sections
w / W Watch list Ctrl+t Cycle theme
Ctrl+e Toggle S2 / Exit API mode Ctrl+r Mark visible as read
Ctrl+h HuggingFace trending Ctrl+Shift+b Remove bookmark
, Settings ? Help / shortcuts
Tab Focus detail pane e Semantic Scholar enrich
a Select all u Clear selection
[ / ] Previous / next date F1 What's New (release notes)

Marks

Press m followed by a letter (az) to set a named mark at the current paper. Press ' followed by that letter to jump back to it. Marks persist within a session, making it easy to navigate between papers you're comparing or revisiting.

⚙️ Configuration

Config lives at ~/.config/arxiv-browser/config.json (Linux), ~/Library/Application Support/arxiv-browser/config.json (macOS), or %APPDATA%/arxiv-browser/config.json (Windows).

Run arxiv-viewer config-path to print the exact path on your machine. API keys for HTTP LLM providers, Semantic Scholar, and embedding services are stored locally in this file; use normal filesystem permissions and avoid committing it.

If you want the best documentation entry point for your context:

See the full documentation for:

🐚 Shell Completions

Enable tab completion for subcommands and flags:

# Bash (add to ~/.bashrc)
eval "$(arxiv-viewer completions bash)"

# Zsh (add to ~/.zshrc)
eval "$(arxiv-viewer completions zsh)"

# Fish (add to ~/.config/fish/config.fish)
arxiv-viewer completions fish | source

🔄 Upgrade / Uninstall

uv tool upgrade arxiv-subscription-viewer
uv tool uninstall arxiv-subscription-viewer

# pip-installed users
python3.13 -m pip install --user --upgrade arxiv-subscription-viewer
python3.13 -m pip uninstall arxiv-subscription-viewer

🛠️ Development

git clone https://github.com/NicolasSchuler/arxiv-subscription-viewer.git
cd arxiv-subscription-viewer
uv python install 3.13
uv sync --locked
pre-commit install
just check   # docs drift + lint + typechecks + tests
just quality # full local quality suite

For contributor-oriented architecture and import-boundary guidance, start with docs/architecture.md.

📄 License

MIT — Nicolas Sebastian Schuler

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

arxiv_subscription_viewer-0.3.5.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

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

arxiv_subscription_viewer-0.3.5-py3-none-any.whl (377.4 kB view details)

Uploaded Python 3

File details

Details for the file arxiv_subscription_viewer-0.3.5.tar.gz.

File metadata

File hashes

Hashes for arxiv_subscription_viewer-0.3.5.tar.gz
Algorithm Hash digest
SHA256 4eb3f6c8ffe7abddf4b64260861d96f3c9bf82725862243661467b3da437edd4
MD5 5605df176b0f01254300c8d0bcc3b669
BLAKE2b-256 174add19d19432d8f8bafa38e72e0f3d07badc9d2e2b372f589ddfc3d4d19f52

See more details on using hashes here.

Provenance

The following attestation bundles were made for arxiv_subscription_viewer-0.3.5.tar.gz:

Publisher: ci-cd.yml on NicolasSchuler/arxiv-subscription-viewer

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

File details

Details for the file arxiv_subscription_viewer-0.3.5-py3-none-any.whl.

File metadata

File hashes

Hashes for arxiv_subscription_viewer-0.3.5-py3-none-any.whl
Algorithm Hash digest
SHA256 5c83f4ae91330c31bb0471807444ae94e378f22d78823be981bdffeda4c7f7fa
MD5 8622badb7be90ef399455be0fe2b1261
BLAKE2b-256 bac1c2d9f6703da2fb9f27fca9f3376c52d17057dfc53ca43fa4a417bf5ebc58

See more details on using hashes here.

Provenance

The following attestation bundles were made for arxiv_subscription_viewer-0.3.5-py3-none-any.whl:

Publisher: ci-cd.yml on NicolasSchuler/arxiv-subscription-viewer

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