Skip to main content

A service for easy weather data acquiring

Project description

WeathEasy

A service for easy weather data acquiring. It uses Zarr as data storage for fast time series queries.

Installation

We highly recommend to use a virtual environment:

python3 -m venv /path/to/venv
. /path/to/venv/bin/activate

On Windows:

python3 -m venv C:\path\to\venv
C:\path\to\venv\Scripts\activate

Install WeathEasy from pypi.org:

python3 -m pip install weatheasy

To install the latest (possibly unreleased) version from the GitHub repository:

python3 -m pip install git+https://github.com/AgroDT/WeathEasy.git

Check installation:

python3 -m weatheasy -v

Extras

By default WeathEasy is only available from command line interface with local storage. The following extras are available to extend its functionality:

  • s3 - enables support for S3-compatible storage for WeathEasy data
  • web - enables web API endpoint

To install WeathEasy with extras run

python3 -m pip install weatheasy[s3,web]

Configuration

WeathEasy web API service is configured with environment variables. Use .example.env as reference. Also you can copy and edit this file as .env or .local.env. WeathEasy will load it automatically.

cp .example.env .env

CLI applications are configured with command line arguments (see below).

Launching

Before running WeathEasy you need to download weather and climate data. As of late 2024 the CFSv2 reanalysis and actual forecast require a total about 65GiB of space. CMIP6 requires about 390GiB of space.

It is also worth updating CFSv2 daily. Just run the download command on a schedule. WeathEasy will download missing reanalysis data and update the forecast if necessary. See below for details.

‼️ The initial download of data may take a long time: from several days to several weeks, depending on network bandwidth, the state of the source data servers, and (possibly) star positions.

Download CLI

To download weather and climate data run:

python3 -m weatheasy.download -d STORE {cfs2,cmip6}

Where STORE can be a local path or an S3 link in format s3://<bucket>/<prefix>.

For S3 you need to export AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY. For any not-AWS S3 storages you also need to export AWS_ENDPOINT_URL_S3. See the Boto3 docs for details.

Optionally you can provide a local path to --download-dir to preserve original downloaded files (GRIB2 for CFSv2 and NetCDF for CMIP6).

A full example for CFSv2:

python3 -m weatheasy.download -d s3://weatheasy/zarr --download-dir ./downloads cfs2

To display the full help message, run:

python3 -m weatheasy.download -h

Query CLI

To query downloaded data run:

python3 -m weatheasy -d STORE -o PATH {cfs2,cmip6} begin end latitude longitude var [var ...]

Where:

  • STORE is the same as for downloading
  • PATH is a path to write results to (by default, results are output to console)
  • begin, end are the date range boundaries in ISO format (yyyy-mm-dd)
  • latitude, longitude are target coordinates in EPSG:4326 coordinate reference system (decimal degrees WGS84)

The command line must ends with a space separated list of target variables to query. To print a full list of available variables run:

python3 -m weatheasy list-vars

A full example for CFSv2, Moscow:

python3 -m weatheasy -d s3://weatheasy/zarr cfs2 \
    2024-01-01 2024-01-31 \
    55.75222 37.61556 \
    TMIN TMAX TMP

To display the full help message, run:

python3 -m weatheasy -h
python3 -m weatheasy cfs2 -h
python3 -m weatheasy cmip6 -h

Web API

After configuring launch the web application with:

uvicorn weatheasy.web:app

By default it would be listening for incoming requests at http://127.0.0.1:8000.

Interactive API docs are available at http://127.0.0.1:8000/docs.

Alternative API docs are available at http://127.0.0.1:8000/redoc.

Read the Uvicorn docs for a full list of supported arguments and options.

Docker

We provide Docker images with all installed dependencies to run WeathEasy. Pull it with:

docker pull ghcr.io/agrodt/weatheasy

The default entry point is the web API. Redefine it to use WeathEasy CLI. For example, to download CFSv2 data with docker run:

docker run --rm -it \
    --entrypoint python \
    ghcr.io/agrodt/weatheasy \
    -m weatheasy.download \
    -d s3://weatheasy/zarr \
    cfs2

Find an example for Docker Compose at examples/docker-compose.

Development

WeathEasy is written in Python and managed by Rye. After cloning this repository, initialize the development environment with:

rye sync --all-features

We also recommend to install and use pre-commit:

rye tools install pre-commit
pre-commit install

You can develop WeathEasy with locally running S3-compatible object storage MinIO. Launch it with:

docker compose -f compose.dev.yml up -d

Also you need to export next variables (see .example.env):

export AWS_ENDPOINT_URL_S3=http://127.0.0.1:9000
export AWS_ACCESS_KEY_ID=minioadmin
export AWS_SECRET_ACCESS_KEY=minioadmin

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

weatheasy-0.2.1.tar.gz (21.0 kB view details)

Uploaded Source

Built Distribution

weatheasy-0.2.1-py3-none-any.whl (20.5 kB view details)

Uploaded Python 3

File details

Details for the file weatheasy-0.2.1.tar.gz.

File metadata

  • Download URL: weatheasy-0.2.1.tar.gz
  • Upload date:
  • Size: 21.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.5

File hashes

Hashes for weatheasy-0.2.1.tar.gz
Algorithm Hash digest
SHA256 f5ab0160257b27361e3f009aa47adb54942b53f795941c6a5f1d4fe117899895
MD5 f8ba2818609882532e579c846843f2bf
BLAKE2b-256 60c9afa48df7a44501fd5d46275ac51d573f49014fbca1d02b2026d7ecb5dcf6

See more details on using hashes here.

File details

Details for the file weatheasy-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: weatheasy-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 20.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.5

File hashes

Hashes for weatheasy-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 993c6cf6a8ca8eaa98e2e35ad592a9a2335f90bd5b954b2ae109671ae9159321
MD5 dc4a6bf82d955e121461b33168c0aa9d
BLAKE2b-256 76e21f59625eb8c2db71d48a70e1fe862f671968eb887e2339152f326929c8db

See more details on using hashes here.

Supported by

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