Skip to main content

MCP server for everyrow: agent ops at spreadsheet scale

Project description

everyrow MCP Server

MCP (Model Context Protocol) server for everyrow: agent ops at spreadsheet scale.

This server exposes everyrow's 5 core operations as MCP tools, allowing LLM applications to screen, rank, dedupe, merge, and run agents on CSV files.

All tools operate on local CSV files. Provide absolute file paths as input, and transformed results are written to new CSV files at your specified output path.

Installation

The server requires an everyrow API key. Get one at everyrow.io/api-key ($20 free credit).

Claude Desktop

Download the latest .mcpb bundle from the GitHub Releases page and double-click to install in Claude Desktop. You'll be prompted to enter your everyrow API key during setup.

Note: The MCPB bundle works in Claude Desktop's Chat mode. Due to a known limitation, local MCP servers are not currently exposed in Cowork mode.

Cursor

Set the environment variable in your terminal shell before opening cursor. You may need to re-open cursor from your shell after this. Alternatively, hardcode the api key within cursor settings instead of the hard-coded ${env:EVERYROW_API_KEY}

export EVERYROW_API_KEY=your_key_here

Install MCP Server

Manual Config

Either set the API key in your shell environment as mentioned above, or hardcode it directly in the config below. Environment variable interpolation may differ between MCP clients.

export EVERYROW_API_KEY=your_key_here

Add this to your MCP config. If you have uv installed:

{
  "mcpServers": {
    "everyrow": {
      "command": "uvx",
      "args": ["everyrow-mcp"],
      "env": {
        "EVERYROW_API_KEY": "${EVERYROW_API_KEY}"
      }
    }
  }
}

Alternatively, install with pip (ideally in a venv) and use "command": "everyrow-mcp" instead of uvx.

Workflow

All operations follow an async pattern:

  1. Start - Call an operation tool (e.g., everyrow_agent) to start a task. Returns immediately with a task ID and session URL.
  2. Monitor - Call everyrow_progress(task_id) repeatedly to check status. The tool blocks ~12s to limit the polling rate.
  3. Retrieve - Once complete, call everyrow_results(task_id, output_path) to save results to CSV.

Available Tools

everyrow_screen

Filter CSV rows based on criteria that require judgment.

Parameters:
- task: Natural language description of screening criteria
- input_csv: Absolute path to input CSV
- response_schema: (optional) JSON schema for custom response fields

Example: Filter job postings for "remote-friendly AND senior-level AND salary disclosed"

everyrow_rank

Score and sort CSV rows based on qualitative criteria.

Parameters:
- task: Natural language instructions for scoring a single row
- input_csv: Absolute path to input CSV
- field_name: Name of the score field to add
- field_type: Type of the score field (float, int, str, bool)
- ascending_order: Sort direction (default: true)
- response_schema: (optional) JSON schema for custom response fields

Example: Rank leads by "likelihood to need data integration solutions"

everyrow_dedupe

Remove duplicate rows using semantic equivalence.

Parameters:
- equivalence_relation: Natural language description of what makes rows duplicates
- input_csv: Absolute path to input CSV

Example: Dedupe contacts where "same person even with name abbreviations or career changes"

everyrow_merge

Join two CSV files using intelligent entity matching.

Parameters:
- task: Natural language description of how to match rows
- left_csv: Absolute path to primary CSV
- right_csv: Absolute path to secondary CSV
- merge_on_left: (optional) Column name in left table
- merge_on_right: (optional) Column name in right table
- use_web_search: (optional) "auto", "yes", or "no"
- relationship_type: (optional) "many_to_one" (default) if multiple left rows can match one right row, or "one_to_one" matches must be unique

Example: Match software products to parent companies (Photoshop -> Adobe)

everyrow_agent

Run web research agents on each row of a CSV.

Parameters:
- task: Natural language description of research task
- input_csv: Absolute path to input CSV
- response_schema: (optional) JSON schema for custom response fields

Example: "Find this company's latest funding round and lead investors"

everyrow_progress

Check progress of a running task.

Parameters:
- task_id: The task ID returned by an operation tool

Blocks ~12s before returning status. Call repeatedly until task completes.

everyrow_results

Retrieve and save results from a completed task.

Parameters:
- task_id: The task ID of the completed task
- output_path: Full absolute path to output CSV file (must end in .csv)

Only call after everyrow_progress reports status "completed".

Development

cd everyrow-mcp
uv sync
uv run pytest

For MCP registry publishing:

mcp-name: io.github.futuresearch/everyrow-mcp

License

MIT - See LICENSE.txt

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

everyrow_mcp-0.3.1.tar.gz (21.7 kB view details)

Uploaded Source

Built Distribution

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

everyrow_mcp-0.3.1-py3-none-any.whl (11.2 kB view details)

Uploaded Python 3

File details

Details for the file everyrow_mcp-0.3.1.tar.gz.

File metadata

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

File hashes

Hashes for everyrow_mcp-0.3.1.tar.gz
Algorithm Hash digest
SHA256 732e4e265d19d09838106779b93345d772967f855529c7f7b99f9fc34bb937c5
MD5 af6dc918e6a48943885f596ac6cc79dd
BLAKE2b-256 ab151ad86819c5aa8ce5640e3440022219e30aee068ec6980708b6fc4b7374e9

See more details on using hashes here.

Provenance

The following attestation bundles were made for everyrow_mcp-0.3.1.tar.gz:

Publisher: publish.yaml on futuresearch/everyrow-sdk

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

File details

Details for the file everyrow_mcp-0.3.1-py3-none-any.whl.

File metadata

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

File hashes

Hashes for everyrow_mcp-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 5ad0b29c9e577cd6b3cf1ce5a5bcb89ad43e8deb5068029aca821dedb1a07a11
MD5 29ac5a989b0e954f8bbc3adb3cdf6f5e
BLAKE2b-256 3d89651c7ee0bc9dcd3f6c5b886012e36133e306cc32c5193a3b8009d1be7331

See more details on using hashes here.

Provenance

The following attestation bundles were made for everyrow_mcp-0.3.1-py3-none-any.whl:

Publisher: publish.yaml on futuresearch/everyrow-sdk

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