Skip to main content

A Python library for the FRED API (Federal Reserve Bank of St. Louis)

Project description

fred-stl

A Python library for the FRED API (Federal Reserve Economic Data, St. Louis Fed).

Work in progress — the library is being built incrementally. New endpoint groups are added with each minor release.

Installation

pip install fred-stl

Requirements

Quick start

import json
import urllib.parse
import urllib.request

from fred import category, for_request

params = category.RequestParams(
    api_key="your-api-key",
    file_type=category.FileType.json,
    category_id=0,
)

url = f"{category.ENDPOINT}?{urllib.parse.urlencode(for_request(params))}"

with urllib.request.urlopen(url) as resp:
    data = json.loads(resp.read())

response = category.Response.model_validate(data)
print(response.categories[0].name)  # "Categories"

Usage

Each FRED endpoint is exposed as a module at the top level of the fred package. Every module provides:

  • RequestParams — a typed, validated model for building requests
  • Response — a typed, validated model for parsing responses
  • ENDPOINT — the API endpoint URL
  • Any enum types needed to construct a request (e.g. FileType, SortOrder)

Use for_request to convert a RequestParams instance into a dict[str, str] ready for any HTTP client:

from fred import for_request, releases

params = releases.RequestParams(
    api_key="your-api-key",
    file_type=releases.FileType.json,
)

query = for_request(params)  # {"api_key": "...", "file_type": "json", ...}

Available endpoints

Category

Module Endpoint
category fred/category
category_children fred/category/children
category_related fred/category/related
category_series fred/category/series
category_tags fred/category/tags
category_related_tags fred/category/related_tags

Releases

Module Endpoint
releases fred/releases
releases_dates fred/releases/dates
release fred/release
release_dates fred/release/dates
release_series fred/release/series
release_sources fred/release/sources
release_tags fred/release/tags
release_related_tags fred/release/related_tags
release_tables fred/release/tables

Series

Module Endpoint
series fred/series
series_categories fred/series/categories
series_observations fred/series/observations
series_release fred/series/release
series_search fred/series/search
series_search_tags fred/series/search/tags
series_search_related_tags fred/series/search/related_tags
series_tags fred/series/tags
series_updates fred/series/updates
series_vintagedates fred/series/vintagedates

Sources

Module Endpoint
sources fred/sources
source fred/source
source_releases fred/source/releases

Tags

Module Endpoint
tags fred/tags
tags_related fred/related_tags
tags_series fred/tags/series

Maps (GeoFRED)

Module Endpoint
geofred_shapes geofred/shapes/file
geofred_series_group geofred/series/group
geofred_series_data geofred/series/data
geofred_regional_data geofred/regional/data

Contributing

See CONTRIBUTING.md.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fred_stl-0.9.2.tar.gz (16.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fred_stl-0.9.2-py3-none-any.whl (72.3 kB view details)

Uploaded Python 3

File details

Details for the file fred_stl-0.9.2.tar.gz.

File metadata

  • Download URL: fred_stl-0.9.2.tar.gz
  • Upload date:
  • Size: 16.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.8 {"installer":{"name":"uv","version":"0.11.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for fred_stl-0.9.2.tar.gz
Algorithm Hash digest
SHA256 9e352b16db730fcb1d143cca4424162eeb1253d64380ac75641ede72cb522f2f
MD5 5fd0e6dbc832447d866ec26adb774be0
BLAKE2b-256 15c2a30655eb772c342fe16563555d252f2784a29349aa834ff5bad58670d08e

See more details on using hashes here.

File details

Details for the file fred_stl-0.9.2-py3-none-any.whl.

File metadata

  • Download URL: fred_stl-0.9.2-py3-none-any.whl
  • Upload date:
  • Size: 72.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.8 {"installer":{"name":"uv","version":"0.11.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for fred_stl-0.9.2-py3-none-any.whl
Algorithm Hash digest
SHA256 9092fe143ee3fd0d66eff806e6e338c97b31e985680370216d6e5af34feea4d0
MD5 e8d0e900a4f8361d27a5281a0805490e
BLAKE2b-256 ee7ca87063d3eb8f153a002e27c7c0fc88fc28e4dce1090d183b62ae9bfae9c3

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page