Skip to main content

AI-agent friendly CLI for Exa — neural web search, URL crawling, and deep research from the terminal.

Project description

中文 · Русский · Português · Español · 日本語 · 한국어

exa-cli

CLI for Exa — neural web search, URL crawling, and AI deep research from the terminal.

PyPI Python 3.11+ License: MIT Stars


What it does

exa-cli wraps the Exa API in three terminal commands. Exa is a search API built for AI applications — it searches by meaning, not keywords, which means it finds relevant pages even when the exact words are not present in the content.

exa-search searches the web. exa-crawl extracts clean readable text from any URL without HTML. exa-research submits a deep research task where Exa AI reads the web and synthesizes a structured answer.

Every command outputs clean --json for use in scripts, pipelines, and AI agent workflows.

Who it is for

  • Developers who want web search access from shell scripts and automation pipelines
  • AI agent developers who need structured, parseable web search output
  • Researchers collecting, filtering, and crawling web content programmatically
  • Anyone using Claude Code, Codex, Cursor, or Windsurf who wants to give their agent web access

Features

  • Neural (semantic) search — finds pages by meaning, not keyword matching
  • Find pages similar to any URL
  • Filter by content type: news, tweet, github, research paper, pdf, and more
  • Filter by date range and domain
  • Full page text extraction from any URL (no HTML)
  • AI deep research tasks with synthesized answers
  • Clean --json output for every command

Installation

uv tool install exa-cli

No uv? Run curl -LsSf https://astral.sh/uv/install.sh | sh, or use pip install exa-search-cli.

Quick start

Get your API key at exa.ai (free tier available):

export EXA_API_KEY=your-key-here
exa-search "how do transformers work" --category "research paper"

Usage

# Neural search
exa-search "vision language models 2025" -n 10

# Find similar pages to a URL
exa-search --similar https://github.com/astral-sh/uv

# Filter by content type and date
exa-search "AI papers" --category "research paper" --start-date 2025-01-01

# Only specific domains
exa-search "documentation" --include-domain docs.python.org,docs.rs

# Exclude noisy domains
exa-search "tutorial" --exclude-domain medium.com,dev.to

# Crawl a page, get clean text
exa-crawl https://example.com -c 8000

# Deep research task
exa-research "current state of quantum error correction"

# JSON output for pipelines
exa-search "topic" --json | jq -r '.results[].url'

All flags — exa-search:

Flag Default Description
-n / --num-results 8 Number of results
-t / --type auto auto · keyword · neural
--text off Fetch and show full page text
--category news · tweet · github · research paper · pdf · company · personal site · linkedin profile · financial report
--start-date Published on or after YYYY-MM-DD
--end-date Published on or before YYYY-MM-DD
--include-domain Comma-separated domains to include only
--exclude-domain Comma-separated domains to exclude
--similar Find pages similar to this URL
--json off Raw JSON output

All flags — exa-crawl: -c / --max-chars (default 5000), --json

All flags — exa-research: -m / --model (exa-research or exa-research-pro), --json

AI agent usage

exa-cli is stateless, read-only, and exits cleanly — designed to be called by AI coding assistants.

# Search and extract URLs (most common agent pattern)
exa-search "topic" --json | jq -r '.results[].url'

# Search → crawl first result
exa-search "topic" --json \
  | jq -r '.results[0].url' \
  | xargs exa-crawl -c 6000

# Find similar pages to a reference URL
exa-search --similar https://example.com --json

# Deep research, get synthesized answer
exa-research "topic" --json

JSON schema for exa-search --json:

{
  "results": [
    {
      "title": "...",
      "url": "...",
      "published_date": "2025-01-15T00:00:00.000Z",
      "author": "...",
      "highlights": ["excerpt..."],
      "text": "full text if --text was passed"
    }
  ]
}

See AGENTS.md for full schemas, exit codes, and environment reference.

Full documentation

Project metadata

  • Author: Nolan Vale
  • Brand: Nolan Vale Tools
  • Focus: search automation, CLI workflows, AI-agent tooling, developer productivity
  • License: MIT

Built by Nolan Vale
Part of Nolan Vale Tools — practical open-source utilities for search, automation, AI agents, and developer workflows.

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

exa_search_cli-0.1.0.tar.gz (49.3 kB view details)

Uploaded Source

Built Distribution

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

exa_search_cli-0.1.0-py3-none-any.whl (7.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: exa_search_cli-0.1.0.tar.gz
  • Upload date:
  • Size: 49.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.15 {"installer":{"name":"uv","version":"0.11.15","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for exa_search_cli-0.1.0.tar.gz
Algorithm Hash digest
SHA256 54ee6770044fd88879cf7bba9f67872d5cc51d315d545d83dccdbc3844abc6f9
MD5 991af71a3660a97f4711eaa6f8a61909
BLAKE2b-256 81f995fab26f069ba661fe260c0fea136950db876994c2eb45591a8f05e03376

See more details on using hashes here.

File details

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

File metadata

  • Download URL: exa_search_cli-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 7.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.15 {"installer":{"name":"uv","version":"0.11.15","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for exa_search_cli-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6e896eebaef88bf4757eebd5611cb0469531e989d67ec5d5e1e2761317642a27
MD5 1b420b5a60276778efaee0e2e6087e82
BLAKE2b-256 8876ed6d339e2ec3c063611ebba0a388867a78c0e55ae88a34c814142f3f779f

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