Meteostat
live WeatherHistoricalHistorical 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
Response
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
Response
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");