What is the gridstatus library?#

gridstatus logo

Tests Code Coverage PyPI Version

The gridstatus open-source library is a Python library maintained by Grid Status that provides a consistent API for accessing raw electricity supply, demand, and pricing data for the major Independent System Operators (ISOs) in the United States and Canada. It currently supports data from CAISO, SPP, ISONE, MISO, ERCOT, NYISO, PJM, IESO, AESO, and the EIA.

GridStatus.io and Hosted API#

This library provides minimally-processed data. If you need production-ready data, consider using our hosted API or visit GridStatus.io to see the data in a web interface.

If you are trying to use our hosted API, you might want to check out the gridstatusio library.

5 Minute Overview#

First, we can see all of the ISOs that are supported

import gridstatus
gridstatus.list_isos()
Name Id Class
0 Midcontinent ISO miso MISO
1 California ISO caiso CAISO
2 PJM pjm PJM
3 Electric Reliability Council of Texas ercot Ercot
4 Southwest Power Pool spp SPP
5 New York ISO nyiso NYISO
6 ISO New England isone ISONE
7 Independent Electricity System Operator ieso IESO

Next, we can select an ISO we want to use

caiso = gridstatus.CAISO()

Fuel Mix#

ISOs share a common API with methods like get_fuel_mix and get_load. Here is how we can get the fuel mix

caiso.get_fuel_mix("today")
2026-06-01 18:24:04 - INFO - Fetching URL: https://www.caiso.com/outlook/current/fuelsource.csv?_=1780338244
Time Interval Start Interval End Solar Wind Geothermal Biomass Biogas Small Hydro Coal Nuclear Natural Gas Large Hydro Batteries Imports Other
0 2026-06-01 00:00:00-07:00 2026-06-01 00:00:00-07:00 2026-06-01 00:05:00-07:00 -63 4057 734 225 172 331 0 2325 1159 4331 2610 7576 0
1 2026-06-01 00:05:00-07:00 2026-06-01 00:05:00-07:00 2026-06-01 00:10:00-07:00 -62 4056 731 222 172 328 0 2326 1235 4000 3645 7270 0
2 2026-06-01 00:10:00-07:00 2026-06-01 00:10:00-07:00 2026-06-01 00:15:00-07:00 -62 4024 729 224 172 327 0 2325 1158 3845 3824 7376 0
3 2026-06-01 00:15:00-07:00 2026-06-01 00:15:00-07:00 2026-06-01 00:20:00-07:00 -62 4021 729 223 171 327 0 2325 1093 3847 3929 7230 0
4 2026-06-01 00:20:00-07:00 2026-06-01 00:20:00-07:00 2026-06-01 00:25:00-07:00 -62 4023 729 225 171 327 0 2325 1096 3962 3715 7263 0
... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ...
132 2026-06-01 11:00:00-07:00 2026-06-01 11:00:00-07:00 2026-06-01 11:05:00-07:00 21308 825 703 224 166 303 0 2326 1124 1301 -7369 -572 0
133 2026-06-01 11:05:00-07:00 2026-06-01 11:05:00-07:00 2026-06-01 11:10:00-07:00 21386 821 704 222 167 306 0 2325 1092 1185 -7715 -211 0
134 2026-06-01 11:10:00-07:00 2026-06-01 11:10:00-07:00 2026-06-01 11:15:00-07:00 21419 849 715 222 168 306 0 2326 1092 1137 -7603 -346 0
135 2026-06-01 11:15:00-07:00 2026-06-01 11:15:00-07:00 2026-06-01 11:20:00-07:00 21448 872 717 222 168 306 0 2325 1099 1114 -7712 -262 0
136 2026-06-01 11:20:00-07:00 2026-06-01 11:20:00-07:00 2026-06-01 11:25:00-07:00 21428 898 718 224 166 306 0 2326 1113 1145 -7758 -302 0

137 rows × 16 columns

Load#

or the energy demand throughout the current day as a Pandas DataFrame

caiso.get_load("today")
2026-06-01 18:24:05 - INFO - Fetching URL: https://www.caiso.com/outlook/current/demand.csv?_=1780338245
Time Interval Start Interval End Load
0 2026-06-01 00:00:00-07:00 2026-06-01 00:00:00-07:00 2026-06-01 00:05:00-07:00 23299.0
1 2026-06-01 00:05:00-07:00 2026-06-01 00:05:00-07:00 2026-06-01 00:10:00-07:00 23609.0
2 2026-06-01 00:10:00-07:00 2026-06-01 00:10:00-07:00 2026-06-01 00:15:00-07:00 23750.0
3 2026-06-01 00:15:00-07:00 2026-06-01 00:15:00-07:00 2026-06-01 00:20:00-07:00 23728.0
4 2026-06-01 00:20:00-07:00 2026-06-01 00:20:00-07:00 2026-06-01 00:25:00-07:00 23665.0
... ... ... ... ...
132 2026-06-01 11:00:00-07:00 2026-06-01 11:00:00-07:00 2026-06-01 11:05:00-07:00 20331.0
133 2026-06-01 11:05:00-07:00 2026-06-01 11:05:00-07:00 2026-06-01 11:10:00-07:00 20378.0
134 2026-06-01 11:10:00-07:00 2026-06-01 11:10:00-07:00 2026-06-01 11:15:00-07:00 20209.0
135 2026-06-01 11:15:00-07:00 2026-06-01 11:15:00-07:00 2026-06-01 11:20:00-07:00 20282.0
136 2026-06-01 11:20:00-07:00 2026-06-01 11:20:00-07:00 2026-06-01 11:25:00-07:00 20244.0

137 rows × 4 columns

Load Forecast#

Another dataset we can query is the load forecast

nyiso = gridstatus.NYISO()
nyiso.get_load_forecast("today")
2026-06-01 18:24:05 - INFO - Requesting http://mis.nyiso.com/public/csv/isolf/20260601isolf.csv
/home/docs/checkouts/readthedocs.org/user_builds/isodata/checkouts/latest/gridstatus/nyiso.py:1226: FutureWarning: Parsed string "05/31/26 07:10 EDT" included an un-recognized timezone "EDT". Dropping unrecognized timezones is deprecated; in a future version this will raise. Instead pass the string without the timezone, then use .tz_localize to convert to a recognized timezone.
  return pd.Timestamp(last_updated_date, tz=self.default_timezone)
Time Interval Start Interval End Forecast Time Load Forecast
0 2026-06-01 00:00:00-04:00 2026-06-01 00:00:00-04:00 2026-06-01 01:00:00-04:00 2026-05-31 07:10:00-04:00 13022
1 2026-06-01 01:00:00-04:00 2026-06-01 01:00:00-04:00 2026-06-01 02:00:00-04:00 2026-05-31 07:10:00-04:00 12530
2 2026-06-01 02:00:00-04:00 2026-06-01 02:00:00-04:00 2026-06-01 03:00:00-04:00 2026-05-31 07:10:00-04:00 12212
3 2026-06-01 03:00:00-04:00 2026-06-01 03:00:00-04:00 2026-06-01 04:00:00-04:00 2026-05-31 07:10:00-04:00 12043
4 2026-06-01 04:00:00-04:00 2026-06-01 04:00:00-04:00 2026-06-01 05:00:00-04:00 2026-05-31 07:10:00-04:00 12174
... ... ... ... ... ...
139 2026-06-06 19:00:00-04:00 2026-06-06 19:00:00-04:00 2026-06-06 20:00:00-04:00 2026-05-31 07:10:00-04:00 19800
140 2026-06-06 20:00:00-04:00 2026-06-06 20:00:00-04:00 2026-06-06 21:00:00-04:00 2026-05-31 07:10:00-04:00 19541
141 2026-06-06 21:00:00-04:00 2026-06-06 21:00:00-04:00 2026-06-06 22:00:00-04:00 2026-05-31 07:10:00-04:00 19181
142 2026-06-06 22:00:00-04:00 2026-06-06 22:00:00-04:00 2026-06-06 23:00:00-04:00 2026-05-31 07:10:00-04:00 18308
143 2026-06-06 23:00:00-04:00 2026-06-06 23:00:00-04:00 2026-06-07 00:00:00-04:00 2026-05-31 07:10:00-04:00 17308

144 rows × 5 columns

Historical Data#

You can use the historical method calls to get data for a specific day in the past. For example,

caiso.get_load("Jan 1, 2020")
2026-06-01 18:24:05 - INFO - Fetching URL: https://www.caiso.com/outlook/history/20200101/demand.csv?_=1780338245
Time Interval Start Interval End Load
0 2020-01-01 00:00:00-08:00 2020-01-01 00:00:00-08:00 2020-01-01 00:05:00-08:00 21533
1 2020-01-01 00:05:00-08:00 2020-01-01 00:05:00-08:00 2020-01-01 00:10:00-08:00 21429
2 2020-01-01 00:10:00-08:00 2020-01-01 00:10:00-08:00 2020-01-01 00:15:00-08:00 21320
3 2020-01-01 00:15:00-08:00 2020-01-01 00:15:00-08:00 2020-01-01 00:20:00-08:00 21272
4 2020-01-01 00:20:00-08:00 2020-01-01 00:20:00-08:00 2020-01-01 00:25:00-08:00 21193
... ... ... ... ...
283 2020-01-01 23:35:00-08:00 2020-01-01 23:35:00-08:00 2020-01-01 23:40:00-08:00 20494
284 2020-01-01 23:40:00-08:00 2020-01-01 23:40:00-08:00 2020-01-01 23:45:00-08:00 20383
285 2020-01-01 23:45:00-08:00 2020-01-01 23:45:00-08:00 2020-01-01 23:50:00-08:00 20297
286 2020-01-01 23:50:00-08:00 2020-01-01 23:50:00-08:00 2020-01-01 23:55:00-08:00 20242
287 2020-01-01 23:55:00-08:00 2020-01-01 23:55:00-08:00 2020-01-02 00:00:00-08:00 20128

288 rows × 4 columns

Frequently, we want to get data across multiple days. We can do that by providing a start and end parameter to any iso.get_* method

caiso_load = caiso.get_load(start="Jan 1, 2021", end="Feb 1, 2021")
caiso_load
Time Interval Start Interval End Load
0 2021-01-01 00:00:00-08:00 2021-01-01 00:00:00-08:00 2021-01-01 00:05:00-08:00 21937.0
1 2021-01-01 00:05:00-08:00 2021-01-01 00:05:00-08:00 2021-01-01 00:10:00-08:00 21858.0
2 2021-01-01 00:10:00-08:00 2021-01-01 00:10:00-08:00 2021-01-01 00:15:00-08:00 21827.0
3 2021-01-01 00:15:00-08:00 2021-01-01 00:15:00-08:00 2021-01-01 00:20:00-08:00 21757.0
4 2021-01-01 00:20:00-08:00 2021-01-01 00:20:00-08:00 2021-01-01 00:25:00-08:00 21664.0
... ... ... ... ...
8923 2021-01-31 23:35:00-08:00 2021-01-31 23:35:00-08:00 2021-01-31 23:40:00-08:00 20054.0
8924 2021-01-31 23:40:00-08:00 2021-01-31 23:40:00-08:00 2021-01-31 23:45:00-08:00 19952.0
8925 2021-01-31 23:45:00-08:00 2021-01-31 23:45:00-08:00 2021-01-31 23:50:00-08:00 19859.0
8926 2021-01-31 23:50:00-08:00 2021-01-31 23:50:00-08:00 2021-01-31 23:55:00-08:00 19763.0
8927 2021-01-31 23:55:00-08:00 2021-01-31 23:55:00-08:00 2021-02-01 00:00:00-08:00 19650.0

8928 rows × 4 columns

We can now see there is data for all of January 2021

import plotly.express as px

fig = px.line(caiso_load, x="Time", y="Load", title="CAISO Load - Jan '21")
fig

Next Steps#

The best part is these APIs work in the same way across all the supported ISOs!

Examples