# filter

`station__dataframe__filter` · external (needs EXECUTION_BACKEND_URL configured) · domain `dataframe` · pv-relevance `non-pv`

Filter rows where a column meets a condition. Operators: eq, neq, gt, gte, lt, lte, contains (string substring). Returns the filtered DataFrame as JSON.

> **Note:** This tool routes through an external execution backend. If `EXECUTION_BACKEND_URL` is unset on the server, calls return JSON-RPC error `-32603 "Tool execution backend not configured"`. Tools with `backend: native` execute in-process and are always callable.

## Agent metadata

- `idempotent`: unknown
- `read_only`: unknown
- `expected_latency_ms`: unknown (not yet contract-tested)
- `cost_tokens_estimate`: unknown

## Input schema

- `columns` *object* (required) — Column name to array of values
- `column` *string* (required) — Column to filter on
- `operator` *string* (required) — Comparison: eq, neq, gt, gte, lt, lte, contains
- `value` *string* (required) — Value to compare against (numbers as strings)

## Example call

```json
POST /api/mcp
Content-Type: application/json

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "tools/call",
  "params": {
    "name": "station__dataframe__filter",
    "arguments": {
      "columns": {},
      "column": "",
      "operator": "",
      "value": ""
    }
  }
}
```

## Related

- [/tools](/tools) — all 3062 tools
- [/tools/dataframe__filter](/tools/dataframe__filter) — HTML page
- [/tools/dataframe__filter/json](/tools/dataframe__filter/json) — JSON form (agent-friendly)
- [/api/mcp](/api/mcp) — endpoint
- [/AGENTS.md](/AGENTS.md) — agent guide
