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.

Setup

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

Either set the API key in your shell environment, or hardcode it directly in the config below.

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.

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
- output_path: Directory or full .csv path for output

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 description of ranking criteria
- input_csv: Absolute path to input CSV
- output_path: Directory or full .csv path for output
- field_name: Name of the score field to add
- field_type: Type of field (float, int, str, bool)
- ascending_order: Sort direction (default: true)

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
- output_path: Directory or full .csv path for output
- select_representative: Keep one row per duplicate group (default: true)

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
- output_path: Directory or full .csv path for output
- merge_on_left: (optional) Column name in left table
- merge_on_right: (optional) Column name in right table

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
- output_path: Directory or full .csv path for output

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

Output Path Handling

The output_path parameter accepts two formats:

  1. Directory: Output file is named {operation}_{input_name}.csv

    • Input: /data/companies.csv, Output path: /output/
    • Result: /output/screened_companies.csv
  2. Full file path: Use the exact path specified

    • Output path: /output/my_results.csv
    • Result: /output/my_results.csv

The server validates output paths before making API requests to avoid wasted costs.

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.1.9.tar.gz (62.0 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.1.9-py3-none-any.whl (8.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: everyrow_mcp-0.1.9.tar.gz
  • Upload date:
  • Size: 62.0 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.1.9.tar.gz
Algorithm Hash digest
SHA256 8a615042fcf5e37caf9318ff8d9b1f7116dcef2e0ae5b986b0d5d695e2dd88ca
MD5 23755b2602523fc2827526fcbebd807d
BLAKE2b-256 c06bcc63c018ba055818b0194d44797c6fda30904f27a38cf918306496100be9

See more details on using hashes here.

Provenance

The following attestation bundles were made for everyrow_mcp-0.1.9.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.1.9-py3-none-any.whl.

File metadata

  • Download URL: everyrow_mcp-0.1.9-py3-none-any.whl
  • Upload date:
  • Size: 8.3 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.1.9-py3-none-any.whl
Algorithm Hash digest
SHA256 6108fbcc246767d7ddf1dc999c7deefdbd8d0ba3e1904cda49544d68113fa871
MD5 8dc8f2bcdddbcb96f986e89e6a20c86c
BLAKE2b-256 a41d69f25d9ca525762c6129e507a6928c9d1006e95da843cc216aaebd8f145e

See more details on using hashes here.

Provenance

The following attestation bundles were made for everyrow_mcp-0.1.9-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