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 dataweb
- 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 downloadingPATH
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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file weatheasy-0.2.0.tar.gz
.
File metadata
- Download URL: weatheasy-0.2.0.tar.gz
- Upload date:
- Size: 20.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7c60aa1f039c75f240df08900ff70625f7b1ebc7c705d206509792b1dfed512e |
|
MD5 | 33b416db79c7b6a155a4e78e0a7c5313 |
|
BLAKE2b-256 | 7277bd868a81ae5237973c4d4b5251238daddb9d0e199069eecb0b66bec67632 |
File details
Details for the file weatheasy-0.2.0-py3-none-any.whl
.
File metadata
- Download URL: weatheasy-0.2.0-py3-none-any.whl
- Upload date:
- Size: 20.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8e55eb6b28155635c81b80f7285c207763cd1b28943e5db8e54586007d36f9eb |
|
MD5 | 288ce4cb1ecb42983dba57b3abe26c26 |
|
BLAKE2b-256 | 80f3cbe56ac61a1b7052eb4c7e372aa9f01c55723acc1f1012c55094872bc4c5 |