Skip to main content

Command-line interface for the OpenAlex API, designed for both human researchers and AI agents

Project description

openalexcli

Command-line interface for the OpenAlex API, designed for both human researchers and AI agents.

Installation

pip install openalexcli

Or with uv:

uv pip install openalexcli

Or run directly without installing:

uvx openalexcli search "machine learning"

For development:

pip install -e .

Usage

Search for works

# Basic search
openalexcli search "machine learning"

# With filters
openalexcli search "transformers" --from-date 2020-01-01 --min-citations 100

# Open access only
openalexcli search "climate change" --open-access

# Output as JSON (auto-detected when piped)
openalexcli search "neural networks" --json

# Output as BibTeX
openalexcli search "attention mechanism" --bibtex

# Group by field (aggregated statistics)
openalexcli search "CRISPR" --group-by publication_year

# Use raw OpenAlex filter syntax
openalexcli search "deep learning" --filter "type:article,is_oa:true"

Get work details

# By OpenAlex ID
openalexcli work W2741809807

# By DOI
openalexcli work "10.1038/nature12373"

# Multiple works
openalexcli work W2741809807 W2100837269

# Export as BibTeX
openalexcli bibtex W2741809807 W2100837269

Citations and references

# Get works that cite a paper
openalexcli citations W2741809807

# Get works cited by a paper
openalexcli references W2741809807

Author commands

# Get author by ID or ORCID
openalexcli author get A5023888391
openalexcli author get "0000-0002-1825-0097"

# Search authors
openalexcli author search "Yann LeCun"

# Get author's works
openalexcli author works A5023888391 --from-date 2020-01-01

# Group author's works by year
openalexcli author works A5023888391 --group-by publication_year

Institution commands

# Get institution by ID or ROR
openalexcli institution get I136199984
openalexcli institution get "ror:03vek6s52"

# Search institutions
openalexcli institution search "MIT"

# Get works from an institution
openalexcli institution works I136199984 --from-date 2023-01-01

Source (journal) commands

# Get source by ID or ISSN
openalexcli source get S137773608
openalexcli source get "0028-0836"

# Search sources
openalexcli source search "Nature"

# Get works from a source
openalexcli source works S137773608 --from-date 2024-01-01

Output Formats

The CLI automatically selects the best output format:

  • Terminal: Human-readable tables (using Rich)
  • Piped output: Compact JSON for machine consumption
  • --json: Force JSON output
  • --bibtex: BibTeX format (for works/publications only)

Polite Pool

OpenAlex provides higher rate limits when you identify yourself with an email:

# Per command
openalexcli search "query" --email your@email.com

# Or set environment variable
export OPENALEX_EMAIL="your@email.com"
openalexcli search "query"

Filter Syntax

Use --filter to pass raw OpenAlex filter expressions:

# Multiple filters (AND)
openalexcli search "AI" --filter "type:article,cited_by_count:>100"

# OR within a filter
openalexcli search "AI" --filter "publication_year:2023|2024"

# Negation
openalexcli search "AI" --filter "type:!book"

See OpenAlex filter documentation for all options.

Group By

Get aggregated statistics instead of individual results:

# Works by type
openalexcli search "machine learning" --group-by type

# Works by year
openalexcli search "quantum computing" --group-by publication_year

# Works by institution
openalexcli search "CRISPR" --group-by authorships.institutions.id

# Author's works by open access status
openalexcli author works A5023888391 --group-by open_access.is_oa

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

openalexcli-0.1.4.tar.gz (16.0 kB view details)

Uploaded Source

Built Distribution

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

openalexcli-0.1.4-py3-none-any.whl (16.9 kB view details)

Uploaded Python 3

File details

Details for the file openalexcli-0.1.4.tar.gz.

File metadata

  • Download URL: openalexcli-0.1.4.tar.gz
  • Upload date:
  • Size: 16.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.3

File hashes

Hashes for openalexcli-0.1.4.tar.gz
Algorithm Hash digest
SHA256 d465cfc0c25d98b7354e74f8c3be7962a5db0b0684ec02668aac87f1fc54cf03
MD5 f5f0330d179dd3990d0b70f2c56d7a70
BLAKE2b-256 930b34509fc723638a55e07049858d261cce9c83416641641d4d12c7ca6f8ba3

See more details on using hashes here.

File details

Details for the file openalexcli-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: openalexcli-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 16.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.3

File hashes

Hashes for openalexcli-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 7c0981f3228a513144d7f44c0a9b802578c8698b8e23fbee62eedf2d9427fa8d
MD5 a656ca91b1c54d8c0c978621c18db16b
BLAKE2b-256 e33c33e499b6820b5275c5e90709c72a2a8bc38e2f1bcf8c43479d09cf00cc51

See more details on using hashes here.

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