Claude-skill-registry gridstatus-api
This skill should be used when the user asks to "get electricity data", "query grid data", "get LMP prices", "fetch load data", "get fuel mix", "query ERCOT data", "query CAISO data", "query PJM data", "get electricity prices", "analyze grid operations", "get ISO data", or mentions electricity market data (load, generation, pricing, LMP, fuel mix, ancillary services, etc.).
git clone https://github.com/majiayu000/claude-skill-registry
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/gridstatus-api" ~/.claude/skills/majiayu000-claude-skill-registry-gridstatus-api && rm -rf "$T"
skills/data/gridstatus-api/SKILL.mdGridStatus API Skill
Query electricity grid data from US Independent System Operators (ISOs) using the GridStatus.io API. Access real-time and historical data for load, pricing (LMP), generation, fuel mix, and more.
Quick Start
IMPORTANT: Always use the Python SDK. The direct curl API has issues with date filtering on the free tier and returns stale sample data. The Python SDK correctly handles all parameters.
Setup
- Install SDK (use uv for isolation):
cd /tmp && uv venv -q && source .venv/bin/activate && uv pip install gridstatusio pandas -q
-
API Key: Check for
in the user'sGRIDSTATUS_API_KEY
file. If not present, instruct the user to:.env- Create account at https://www.gridstatus.io
- Get API key from Settings page
- Add to
:.envGRIDSTATUS_API_KEY=your_key_here
-
Query data:
import os os.environ['GRIDSTATUS_API_KEY'] = 'key_from_dotenv' from gridstatusio import GridStatusClient client = GridStatusClient() df = client.get_dataset( dataset="isone_fuel_mix", start="2026-01-25", end="2026-01-26", limit=100 ) print(df.tail())
Free tier limit: 500,000 rows per month. Always use
limit parameter.
Supported ISOs
| ISO | Region | Key Datasets |
|---|---|---|
| ERCOT | Texas | , , |
| CAISO | California | , , |
| PJM | Mid-Atlantic/Midwest | , , |
| MISO | Midwest | , |
| NYISO | New York | , |
| ISO-NE | New England | , , |
| SPP | Southwest/Central | , |
See
references/datasets-by-iso.md for complete dataset catalog.
Standard Query Template
Use this template for all queries. Run in a Python heredoc:
cd /tmp && source .venv/bin/activate && python3 << 'EOF' import os os.environ['GRIDSTATUS_API_KEY'] = 'YOUR_KEY_HERE' from gridstatusio import GridStatusClient client = GridStatusClient() df = client.get_dataset( dataset="DATASET_NAME", start="YYYY-MM-DD", end="YYYY-MM-DD", limit=100 ) print(df.to_string()) EOF
Common Query Patterns
Current Fuel Mix (What's generating now?)
df = client.get_dataset( dataset="isone_fuel_mix", # or ercot_fuel_mix, caiso_fuel_mix start="2026-01-25", end="2026-01-26", limit=500 ) latest = df.iloc[-1] total = latest[['coal','hydro','natural_gas','nuclear','oil','solar','wind','wood','refuse','other']].sum() print(f"Oil: {latest['oil']:.0f} MW ({latest['oil']/total*100:.1f}%)")
System Load
df = client.get_dataset( dataset="pjm_load", start="2026-01-25", end="2026-01-26", timezone="US/Eastern", limit=100 ) print(f"Current load: {df.iloc[-1]['load']:,.0f} MW")
Electricity Prices (LMP)
df = client.get_dataset( dataset="ercot_spp_real_time_15_min", start="2026-01-25", end="2026-01-26", filter_column="location", filter_value="HB_HOUSTON", limit=100 ) print(f"Houston price: ${df.iloc[-1]['spp']:.2f}/MWh")
Zone-Specific Load (Standardized Datasets)
df = client.get_dataset( dataset="pjm_standardized_hourly", start="2026-01-25", end="2026-01-26", timezone="market" ) # Zone data in columns: df['load.comed'], df['load.aep'], etc. print(f"ComEd load: {df.iloc[-1]['load.comed']:,.0f} MW")
Dataset Discovery
Check Dataset Metadata (date range, columns)
# Get dataset info including available date range import requests import os api_key = os.environ.get('GRIDSTATUS_API_KEY') r = requests.get(f"https://api.gridstatus.io/v1/datasets/pjm_load", headers={"x-api-key": api_key}) meta = r.json() print(f"Available: {meta['earliest_available_time_utc']} to {meta['latest_available_time_utc']}") print(f"Columns: {[c['name'] for c in meta['all_columns']]}")
List Datasets
client.list_datasets(filter_term="ercot") # Search by keyword datasets = client.list_datasets(filter_term="fuel_mix", return_list=True)
Dataset naming convention:
{iso}_{data_type}_{frequency}
- ERCOT system loadercot_load
- CAISO 5-minute real-time LMPscaiso_lmp_real_time_5_min
- PJM day-ahead hourly LMPspjm_lmp_day_ahead_hourly
Energy Calculations
Load (MW) measures instantaneous power. Energy (MWh) = power x time.
| Data Frequency | Energy Formula | Example |
|---|---|---|
| 5-minute | | 100,000 MW x 0.0833 = 8,333 MWh |
| 15-minute | | 100,000 MW x 0.25 = 25,000 MWh |
| Hourly | | 100,000 MW x 1 = 100,000 MWh |
# Total energy for a period (5-min data) total_mwh = (df['load'] * (5/60)).sum() total_gwh = total_mwh / 1000
Query Parameters Reference
| Parameter | Type | Description |
|---|---|---|
| str | Required. Dataset ID (e.g., ) |
| str | Start date (YYYY-MM-DD or ISO format) |
| str | End date |
| int | Max rows to return |
| str | for ISO local time, or etc. |
| str | Column to filter on |
| str/list | Value(s) to match |
| str | , , , , , , |
| str | Aggregate frequency (, ) |
| str | , , , |
See
references/api-reference.md for complete documentation.
Troubleshooting
| Issue | Cause | Fix |
|---|---|---|
| Old/stale data returned | Using curl directly | Use Python SDK instead - curl has date filtering issues on free tier |
| 401 Unauthorized | Invalid/missing API key | Check is set correctly |
| Empty DataFrame | Date range outside coverage | Check dataset metadata for available date range |
| ModuleNotFoundError | SDK not installed | Run: |
| "Unknown column" error | Wrong filter column | Zone data is in columns after fetch, not filterable. Use |
| 429 Rate Limited | Too many requests | SDK auto-retries with backoff |
Why Not curl?
The direct HTTP API has a critical issue on the free tier: date parameters are ignored and it returns sample data from years ago. The Python SDK correctly handles date filtering and returns current data.
If you must use curl (e.g., for dataset metadata), it works for non-query endpoints:
# This works - metadata endpoint curl -s -H "x-api-key: $GRIDSTATUS_API_KEY" \ "https://api.gridstatus.io/v1/datasets/pjm_load" # This returns stale data - query endpoint has issues curl -s -H "x-api-key: $GRIDSTATUS_API_KEY" \ "https://api.gridstatus.io/v1/datasets/pjm_load/query?start=2026-01-25" # BROKEN
Additional Resources
Reference Files
- Complete dataset catalog by ISOreferences/datasets-by-iso.md
- Full API parameter documentationreferences/api-reference.md
- Ready-to-use query patternsreferences/common-queries.md
Example Files
- Python SDK examplesexamples/python-query.py