Meteostat

live WeatherHistorical

Historical weather from 11,000+ stations via free bulk CSVs. Station-level readings (no interpolation). No auth.

2 tools
0ms auth
free tier 50 calls/day

Tools

get_daily_history required: station_id, start_date, end_date

Daily readings between two dates for a Meteostat station.

Parameters
Name Type Description
station_id req string Meteostat numeric station ID
start_date req string YYYY-MM-DD
end_date req string YYYY-MM-DD
Try it
get_monthly_normals required: station_id

Long-run monthly climate normals for a station.

Parameters
Name Type Description
station_id req string Meteostat numeric station ID
Try it

Test with curl

The gateway speaks JSON-RPC 2.0 over HTTP POST. You can test any pack directly from the terminal.

List available tools
bash
curl -X POST https://gateway.pipeworx.io/meteostat/mcp \
  -H "Content-Type: application/json" \
  -d '{"jsonrpc":"2.0","id":1,"method":"tools/list"}'
Call a tool
bash
curl -X POST https://gateway.pipeworx.io/meteostat/mcp \
  -H "Content-Type: application/json" \
  -d '{"jsonrpc":"2.0","id":2,"method":"tools/call","params":{"name":"get_daily_history","arguments":{"station_id": "example", "start_date": "2025-01-01", "end_date": "2025-01-01"}}}'

Use with the SDK

Install @pipeworx/sdk to call tools from any TypeScript/Node project.

TypeScript
import { Pipeworx } from '@pipeworx/sdk';
const px = new Pipeworx();
const result = await px.call("get_daily_history", {"station_id":"example","start_date":"example","end_date":"example"});
ask_pipeworx
// Or ask in plain English:
const answer = await px.ask("historical weather from 11,000+ stations via free bulk csvs");