Skip to main content

A Python library for accessing MeteoAlarm weather warnings

Project description

MeteoAlarm Python Library

A Python library for accessing and filtering weather warnings from MeteoAlarm's CAP (Common Alerting Protocol) feeds. This library provides easy access to weather warnings across European countries through MeteoAlarm's official feeds.

Features

  • Access weather warnings for multiple European countries
  • Filter warnings based on various attributes (severity, type, description, etc.)
  • Support for multiple languages per warning
  • Automatic parsing of CAP format warnings
  • GeoJSON geometry support for warning areas
  • Timezone-aware datetime handling

Installation

Install the package using pip:

pip install meteoalarm

Quickstart

from meteoalarm import MeteoAlarm

# Initialize with one or more countries
warnings = MeteoAlarm(["estonia", "denmark"])

# Print all warnings
for warning in warnings:
    print(f"\nWarning for {warning.area["areaDesc"]} ({warning.country}):")
    print(f"Headline: {warning.get_headline("en-EN")}")
    print(f"Severity: {warning.severity}")
    print(f"Valid until: {warning.expires}")

Filtering Warnings

The library provides flexible filtering capabilities:

# Filter by severity
severe_warnings = warnings.filter(severity="Severe")

# Filter by description content (searches in all languages)
wind_warnings = warnings.filter(description="wind")

# Filter by multiple criteria
specific_warnings = warnings.filter(
    country="estonia",
    severity="Moderate",
    awareness_type="Wind"
)

# Chain filters
critical_wind = warnings.filter(awareness_type="Wind").filter(severity="Severe")

Multilingual Support

Warnings are available in multiple languages:

# Get available languages for a warning
languages = warning.get_available_languages()

# Get warning information in specific language
english_headline = warning.get_headline("en-EN")
estonian_desc = warning.get_description("et-ET")

Plotting the Warning Area

from shapely.geometry import shape
import geopandas as gpd
import matplotlib.pyplot as plt
import contextily as ctx
import json

# Parse the GeoJSON string
geojson_dict = json.loads(warnings[0].geometry)

# Create geometry object
geometry = shape(geojson_dict)

# Create GeoDataFrame directly
gdf = gpd.GeoDataFrame(geometry=[geometry], crs="EPSG:4326")

# Convert to Web Mercator projection for contextily
gdf_web = gdf.to_crs(epsg=3857)

# Create plot
fig, ax = plt.subplots(figsize=(10, 10))
gdf_web.plot(ax=ax, alpha=0.5, color='red')

# Add background map
ctx.add_basemap(ax)

plt.axis('off')
plt.show()

Warning Attributes

Each warning object contains the following attributes:

  • category: Warning category
  • event: Event type
  • urgency: Urgency level
  • severity: Severity level
  • certainty: Certainty level
  • onset: Start time (datetime object)
  • effective: Effective time (datetime object)
  • expires: Expiration time (datetime object)
  • sender: Dictionary containing sender information
  • headline: Dictionary of headlines in available languages
  • description: Dictionary of descriptions in available languages
  • awareness_level: Awareness level
  • awareness_type: Type of weather warning
  • area: Dictionary containing area description and EMMA_ID
  • geometry: GeoJSON geometry of the warning area

Requirements

  • Python 3.7+
  • requests
  • pytz
  • pyyaml

License

This project is licensed under the MIT License - see the LICENSE file for details.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Acknowledgments

  • Data provided by MeteoAlarm
  • Based on the CAP (Common Alerting Protocol) standard

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

meteoalarm-0.1.9.tar.gz (12.4 MB view details)

Uploaded Source

Built Distribution

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

meteoalarm-0.1.9-py3-none-any.whl (12.4 MB view details)

Uploaded Python 3

File details

Details for the file meteoalarm-0.1.9.tar.gz.

File metadata

  • Download URL: meteoalarm-0.1.9.tar.gz
  • Upload date:
  • Size: 12.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for meteoalarm-0.1.9.tar.gz
Algorithm Hash digest
SHA256 d68c485c8457a2bb04c56038de32959dcb6bf014de6a9e51d1bff67c58249b8f
MD5 a7c4a4a898f5f5819cad9ed247a91de7
BLAKE2b-256 42f3c5e149cb6a398a8f912a23e35104c45d31878eefd2070adaf13bd8909bfb

See more details on using hashes here.

Provenance

The following attestation bundles were made for meteoalarm-0.1.9.tar.gz:

Publisher: python-publish.yml on NiklasJordan/meteoalarm

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file meteoalarm-0.1.9-py3-none-any.whl.

File metadata

  • Download URL: meteoalarm-0.1.9-py3-none-any.whl
  • Upload date:
  • Size: 12.4 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for meteoalarm-0.1.9-py3-none-any.whl
Algorithm Hash digest
SHA256 5ac2926a34fc287fa07fcad27e0ac7b89f8dc4ab197a0424a25711ef855ec9b3
MD5 5f370b20379f509b48fbbab9b67fa5ff
BLAKE2b-256 0487f439e3cbc819d6b85b602eef8f904326862b4217addbffb68d6a7480dc46

See more details on using hashes here.

Provenance

The following attestation bundles were made for meteoalarm-0.1.9-py3-none-any.whl:

Publisher: python-publish.yml on NiklasJordan/meteoalarm

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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