Skip to main content

Python client for the Beach Day API — real-time beach and surf conditions

Project description

Beach Day API — Python Client

PyPI version Python License: MIT

Python client for the Beach Day API — water quality, weather, tides, ocean conditions, beach rules, amenities, and composite scoring in a single call. Covers 4,732 beaches across the US, Australia, South Africa, and Spain.

pip install beachdayapi

Quick Start

from beachdayapi import BeachDayAPI

client = BeachDayAPI("bda_your_api_key")

# Search beaches by state
beaches = client.beaches.list(state="CA")
for b in beaches["data"]:
    print(b["name"], b["state"])

# Search beaches by name
malibu = client.beaches.list(search="Malibu")
print(f"Found {malibu['count']} beaches matching 'Malibu'")

# Get full detail for a beach
beach = client.beaches.get(372)
print(beach["data"]["name"], beach["data"]["beach_day_score"])

# Get current conditions
conditions = client.beaches.conditions(372)
print(conditions["data"]["water_quality_grade"])

# Get top-scored beaches
scored = client.beaches.scored(min_score=70, limit=10)
for b in scored["data"]:
    print(f"{b['name']}: {b['beach_day_score']}")

# Health check (no API key needed)
health = client.health()
print(health)

API Key

Sign up at beachdayapi.com to get your free API key (50 free credits, no credit card). Your key starts with bda_.

You can also set the BEACHDAY_API_KEY environment variable:

import os
from beachdayapi import BeachDayAPI

client = BeachDayAPI(os.environ["BEACHDAY_API_KEY"])

Endpoints

Method Endpoint Cost Description
client.health() GET /v1/health Free API health check
client.beaches.list() GET /v1/beaches 1 credit Search beaches
client.beaches.get(id) GET /v1/beaches/{id} 5 credits Beach detail
client.beaches.conditions(id) GET /v1/beaches/{id}/conditions 3 credits Current conditions
client.beaches.scored() GET /v1/beaches/scored 10 credits Scored beaches

Error Handling

from beachdayapi import (
    BeachDayAPI,
    AuthenticationError,
    InsufficientCreditsError,
    NotFoundError,
    RateLimitError,
    ServerError,
)

client = BeachDayAPI("bda_invalid_key")

try:
    client.beaches.list(state="CA")
except AuthenticationError:
    print("Check your API key")
except InsufficientCreditsError:
    print("Buy more credits at beachdayapi.com/credits/pricing/")
except RateLimitError:
    print("Slow down")

Requirements

  • Python 3.9+
  • Zero dependencies (stdlib only)

License

MIT — see the main Beach Day API repository.

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

beachdayapi-0.1.1.tar.gz (4.6 kB view details)

Uploaded Source

Built Distribution

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

beachdayapi-0.1.1-py3-none-any.whl (5.3 kB view details)

Uploaded Python 3

File details

Details for the file beachdayapi-0.1.1.tar.gz.

File metadata

  • Download URL: beachdayapi-0.1.1.tar.gz
  • Upload date:
  • Size: 4.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for beachdayapi-0.1.1.tar.gz
Algorithm Hash digest
SHA256 25aa10309c2866d52984b5b7e8307cfc2015c26d50aeca2535777763bc813507
MD5 127e08737bdacef3ed79c00a6bb2239f
BLAKE2b-256 931739c8c48e82511e001ae6763904b7a6d078a88229a8d61bcd29387acd8914

See more details on using hashes here.

File details

Details for the file beachdayapi-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: beachdayapi-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 5.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for beachdayapi-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 793c975900a0f9428c5218956226ec315522f4bbb55bedd95e39d1e53c7ea8c7
MD5 86eecbbf03c8123113d3cec0405b128f
BLAKE2b-256 c5839db171d8f30c233b4f790ab677af3a9068ab10780fb53d4172823ed3442d

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