Skip to main content

Scientific paper search and ranking across OpenAlex, Semantic Scholar, and Unpaywall

Project description

paper-search

Search and rank scientific papers across multiple academic APIs from the command line.

Queries OpenAlex (250M+ works), Semantic Scholar (215M+ papers), and Unpaywall in parallel, merges results by DOI, and outputs ranked papers with citation counts, TLDRs, and PDF links. Use --save to persist results to .claude/papers.md for use as project context in Claude Code.

Installation

uv tool install paper-search

Or from source:

git clone https://github.com/Csed-dev/paper-search.git
cd paper-search
uv sync

Quick Start

# Search papers by topic, ranked by citations
paper-search search "large language models" -n 10

# Filter by year
paper-search search "vision transformers" --year 2024 --sort date

# Find similar papers (accepts DOI, arXiv ID, or Semantic Scholar ID)
paper-search recommend 1706.03762 -n 10

# Save results to .claude/papers.md in current project
paper-search search "reinforcement learning" --save

# Enable PDF links via Unpaywall
paper-search search "graph neural networks" --email you@example.com

Example Output

$ paper-search search "attention mechanism" -n 5

  Results for: attention mechanism
  5 papers, sorted by citations

    1. Faster R-CNN: Towards Real-Time Object Detection with Region Proposal Networks (2016) [52848 citations] (9606 influential) [OA]
       Shaoqing Ren, Kaiming He, Ross Girshick, Jian Sun
       DOI: 10.1109/tpami.2016.2577031
       PDF: https://arxiv.org/pdf/1506.01497

    2. Effective Approaches to Attention-based Neural Machine Translation (2015) [8517 citations] [OA]
       Thang Luong, Hieu Pham, Christopher D. Manning
       DOI: 10.18653/v1/d15-1166

    3. Attention mechanisms in computer vision: A survey (2022) [2242 citations] [OA]
       Meng-Hao Guo, Tian-Xing Xu, Jiangjiang Liu, Zheng-Ning Liu, Peng-Tao Jiang +5 more
       DOI: 10.1007/s41095-022-0271-y
       PDF: https://arxiv.org/pdf/2111.07624

What It Does

paper-search search "query"
        |
        +--- OpenAlex ---------- phrase search, topic taxonomy, citation ranking
        |
        +--- Semantic Scholar -- TLDR summaries, influential citations
        |
        +--- Unpaywall --------- OA PDF links (when --email is set)
        |
        v
    Merge by DOI -> Rank -> Display / Save

Results include: title, authors, citation count (with influential count from S2), abstract, TLDR, DOI, PDF link, and topics.

Commands

search (alias: s)

paper-search search "query" [options]
Flag Description
-n, --limit N Number of results (default: 10)
-y, --year YYYY Filter by publication year
--sort citations|date|relevance Sort order (default: citations)
--save Append results to .claude/papers.md
--email EMAIL Enable Unpaywall PDF links + faster OpenAlex
--s2-key KEY Semantic Scholar API key

recommend (alias: r)

paper-search recommend <paper_id> [options]

Accepts DOI (10.1038/s41586-023-06291-2), arXiv ID (1706.03762, hep-th/9905111), or Semantic Scholar ID.

Same --save, --email, --s2-key, -n flags as search.

Environment Variables

Set these to avoid passing flags every time:

Variable Description
PAPER_SEARCH_EMAIL Email for OpenAlex polite pool + Unpaywall
PAPER_SEARCH_S2_KEY Semantic Scholar API key

The --save Flag

When used inside a project directory, --save writes results to .claude/papers.md. This file persists as context for Claude Code, making your paper references available in future conversations.

cd my-research-project
paper-search search "federated learning" -n 15 --save
# Creates .claude/papers.md with formatted paper references

Running the same query twice with --save won't duplicate the section.

API Keys (Free)

Both APIs offer free keys for higher rate limits:

The tool works without keys, just with lower rate limits.

Development

git clone https://github.com/Csed-dev/paper-search.git
cd paper-search
uv sync --group dev
uv run pytest

Tests use captured API fixtures (no network calls):

uv run pytest tests/ -v    # 71 tests, runs in <1s

To refresh fixtures from live APIs:

uv run python tests/capture_fixtures.py

Contributing

See CONTRIBUTING.md for guidelines.

License

MIT

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

paper_search-0.2.0.tar.gz (482.5 kB view details)

Uploaded Source

Built Distribution

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

paper_search-0.2.0-py3-none-any.whl (15.0 kB view details)

Uploaded Python 3

File details

Details for the file paper_search-0.2.0.tar.gz.

File metadata

  • Download URL: paper_search-0.2.0.tar.gz
  • Upload date:
  • Size: 482.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for paper_search-0.2.0.tar.gz
Algorithm Hash digest
SHA256 1b13aa44e8218cb14a9b115becfb183a3dc43cdca7b2871fed77213a3fc878ca
MD5 632beb99e310fc9d4e09358ab3e78028
BLAKE2b-256 773fffe0855c76657daed985327b2e4e1e2b93201c204c0aacc972fbc4c65717

See more details on using hashes here.

Provenance

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

Publisher: release.yml on Csed-dev/paper-search

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

File details

Details for the file paper_search-0.2.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for paper_search-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f7f40ddb2dc6e8cd533435025f473172b308ebd3bcbcb1907126c764db60662f
MD5 4370c28e21d8ac0f4343311468050b33
BLAKE2b-256 bc384649857e89a28ec8aaf013ba6f1b1ff096f436cd83686d2dd449a7ea48e7

See more details on using hashes here.

Provenance

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

Publisher: release.yml on Csed-dev/paper-search

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