© [Institute of Urban Water Management and Landscape Water Engineering](https://www.tugraz.at),
[Graz University of Technology](https://www.tugraz.at/home/) and [Markus Pichler](mailto:markus.pichler@tugraz.at)
# eHYD Tools
[![license](https://img.shields.io/github/license/markuspic/ehyd_tools.svg?style=flat)](https://github.com/MarkusPic/ehyd_tools/blob/master/LICENSE)
[![PyPI](https://img.shields.io/pypi/v/ehyd_tools.svg)](https://pypi.python.org/pypi/ehyd-tools)
Reading and analyzing hydro(geo)logic time series from the Austrian government's "ehyd.gv.at" platform.
Various tools for exporting and analyzing >10a rain time-series from the [ehyd.gv.at](https://ehyd.gv.at) platform of the Austian government.
If you are interested in a statistical heavy rain analysis like on *(Ö)Kostra*, take a look at my other python package [intensity_duration_frequency_analysis](https://github.com/MarkusPic/intensity_duration_frequency_analysis) which is compatible with this package.
# Install
The script is written in Python3. (use a version > 3.5)
## Windows
You have to install python (i.e. the original python from the [website](https://www.python.org/downloads/)).
The following commands show the usage for Linux/Unix systems.
To use these features on Windows you have to add ```python -m``` before each command
and you have to add the path to your python binary to the environment variables [^path1].
[^path1]: https://geek-university.com/python/add-python-to-the-windows-path/
There is also an option during the installation to add python to the PATH automatically. [^path2]
[^path2]: https://datatofish.com/add-python-to-windows-path/
![python_install](https://datatofish.com/wp-content/uploads/2018/10/0001_add_Python_to_Path.png)
## Linux/Unix
Python is pre-installed on most operating systems (as you probably knew).
## Required python packages
Packages required for this program will be installed with pip during the installation process and can be seen in the [`requirements.txt`](requirements.txt) file.
```mermaid
flowchart TD
classDef missing stroke-dasharray: 5
argh["argh<br>0.31.3"]
certifi["certifi<br>2023.7.22"]
charset-normalizer["charset-normalizer<br>3.3.0"]
contourpy["contourpy<br>1.3.0"]
cycler["cycler<br>0.12.1"]
fonttools["fonttools<br>4.43.1"]
idna["idna<br>3.4"]
kiwisolver["kiwisolver<br>1.4.5"]
matplotlib["matplotlib<br>3.8.0"]
numpy["numpy<br>1.26.1"]
packaging["packaging<br>24.1"]
pandas["pandas<br>2.2.3"]
pillow["Pillow<br>10.1.0"]
pyparsing["pyparsing<br>3.1.1"]
python-dateutil["python-dateutil<br>2.8.2"]
pytz["pytz<br>2023.3.post1"]
requests["requests<br>2.31.0"]
six["six<br>1.16.0"]
tzdata["tzdata<br>2023.3"]
urllib3["urllib3<br>2.0.6"]
contourpy -- "≥1.23" --> numpy
matplotlib -- "≥0.10" --> cycler
matplotlib -- "≥1.0.1" --> contourpy
matplotlib -- "≥1.0.1" --> kiwisolver
matplotlib -- "≥1.21,<2" --> numpy
matplotlib -- "≥2.3.1" --> pyparsing
matplotlib -- "≥2.7" --> python-dateutil
matplotlib -- "≥20.0" --> packaging
matplotlib -- "≥4.22.0" --> fonttools
matplotlib -- "≥6.2.0" --> pillow
pandas -- "≥1.26.0" --> numpy
pandas -- "≥2.8.2" --> python-dateutil
pandas -- "≥2020.1" --> pytz
pandas -- "≥2022.7" --> tzdata
python-dateutil -- "≥1.5" --> six
requests -- "≥1.21.1,<3" --> urllib3
requests -- "≥2,<4" --> charset-normalizer
requests -- "≥2.5,<4" --> idna
requests -- "≥2017.4.17" --> certifi
```
## Fresh install
```bash
pip install ehyd-tools
```
Add the following tags to the command for special options:
- ```--user```: To install the package only for the local user account (no admin rights needed)
- ```--upgrade```: To update the package
# Alternative Repositories
- https://github.com/hydrogeology-graz/ehyd
- https://github.com/joha1/ehyd_reader
# Usage for general time-series data
### Examples Jupyter notebooks for Extended python API
> links only work on GitHub!
- [the design rainfall](example/example_design_rainfall.ipynb)
- [model rain creator](example/example_synthetic_rain.ipynb)
- [the general data-reader](example/example_python_api_general.ipynb)
- [the gis extract](example/example_gis_export.ipynb)
# Usage for high-res precipitation time-series
To start the script use following commands in the terminal/Prompt
```ehyd_tools```
## Commandline tool
With the `-h` (help) flag you can see the complete functionality of the tool.
```bash
ehyd_tools -h
```
> ```
> usage: __main__.py [-h] [-id ID] [--input INPUT] [--max10a] [--start START]
> [--end END] [--add_gaps] [--to_csv] [--to_parquet] [--plot]
> [--statistics] [--meta] [--unix]
>
> optional arguments:
> -h, --help show this help message and exit
> -id ID the id number for the station from the ehyd.gv.at platform
> --input INPUT path to the rain input file including the filename
> --max10a consider only 10 years with the most availability (for
> clipping the data)
> --start START custom start time (Format="YYYY-MM-DD") for clipping the data
> --end END custom end time (Format="YYYY-MM-DD") for clipping the data
> --add_gaps save a gaps-table as a csv-file
> --to_csv save the time-series as csv-file (to the current directory if
> the id is used or in the directory of the input-file)
> --to_parquet save the time-series as parquet-file (to the current
> directory if the id is used or in the directory of the input-
> file) - parquet is a much faster as csv to read and write
> --plot save a bar-plot with monthly sums and availability as a png-
> file
> --statistics save the basic statistics (sum, max & min) as a txt-file
> --meta save the meta-data presented in ehyd as a txt-file
> --unix export the csv files with a "," as separator and a "." as
> decimal sign (otherwise ";" as separator and a "," as decimal
> sign will be used)
> ```
## The high-res precipitation stations
> links only work on GitHub!
[List of ehyd-stations with the id-number and the label](ehyd_tools/ehyd_stations.json)
## Examples
> links only work on GitHub!
[Example Jupyter notebook for the commandline](example/example_commandline.ipynb)
[Example Jupyter notebook for the python api](example/example_python_api.ipynb)
[Example python skript](example/example_python_api.py)
### Example results files
> links only work on GitHub!
[Data-gaps in the series](example/ehyd_112086_gaps.csv)
[Meta-data of the series](example/ehyd_112086_meta.txt)
### Example Plot
> links only work on GitHub!
![Regenhöhenlinien](example/ehyd_112086_plot.png)
Raw data
{
"_id": null,
"home_page": null,
"name": "ehyd-tools",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.7",
"maintainer_email": null,
"keywords": "austria, precipitation, groundwater, hydrology, data, environment, civil_engineering, api",
"author": null,
"author_email": "Markus Pichler <markus.pichler@tugraz.at>",
"download_url": "https://files.pythonhosted.org/packages/d4/29/b9a5631b025cfa2c884adbbf76390d2c85ba5a67627d7cf852192a0c8424/ehyd_tools-0.1.7.tar.gz",
"platform": null,
"description": "\u00a9 [Institute of Urban Water Management and Landscape Water Engineering](https://www.tugraz.at), \n[Graz University of Technology](https://www.tugraz.at/home/) and [Markus Pichler](mailto:markus.pichler@tugraz.at)\n\n# eHYD Tools\n\n[![license](https://img.shields.io/github/license/markuspic/ehyd_tools.svg?style=flat)](https://github.com/MarkusPic/ehyd_tools/blob/master/LICENSE)\n[![PyPI](https://img.shields.io/pypi/v/ehyd_tools.svg)](https://pypi.python.org/pypi/ehyd-tools)\n\nReading and analyzing hydro(geo)logic time series from the Austrian government's \"ehyd.gv.at\" platform.\n\nVarious tools for exporting and analyzing >10a rain time-series from the [ehyd.gv.at](https://ehyd.gv.at) platform of the Austian government.\n\nIf you are interested in a statistical heavy rain analysis like on *(\u00d6)Kostra*, take a look at my other python package [intensity_duration_frequency_analysis](https://github.com/MarkusPic/intensity_duration_frequency_analysis) which is compatible with this package.\n\n# Install\n\nThe script is written in Python3. (use a version > 3.5)\n\n## Windows\n\nYou have to install python (i.e. the original python from the [website](https://www.python.org/downloads/)).\n\nThe following commands show the usage for Linux/Unix systems. \n\nTo use these features on Windows you have to add ```python -m``` before each command \nand you have to add the path to your python binary to the environment variables [^path1].\n\n[^path1]: https://geek-university.com/python/add-python-to-the-windows-path/\n\nThere is also an option during the installation to add python to the PATH automatically. [^path2]\n\n[^path2]: https://datatofish.com/add-python-to-windows-path/\n\n![python_install](https://datatofish.com/wp-content/uploads/2018/10/0001_add_Python_to_Path.png)\n\n## Linux/Unix\n\nPython is pre-installed on most operating systems (as you probably knew).\n\n## Required python packages\n\nPackages required for this program will be installed with pip during the installation process and can be seen in the [`requirements.txt`](requirements.txt) file.\n\n```mermaid\nflowchart TD\n classDef missing stroke-dasharray: 5\n argh[\"argh<br>0.31.3\"]\n certifi[\"certifi<br>2023.7.22\"]\n charset-normalizer[\"charset-normalizer<br>3.3.0\"]\n contourpy[\"contourpy<br>1.3.0\"]\n cycler[\"cycler<br>0.12.1\"]\n fonttools[\"fonttools<br>4.43.1\"]\n idna[\"idna<br>3.4\"]\n kiwisolver[\"kiwisolver<br>1.4.5\"]\n matplotlib[\"matplotlib<br>3.8.0\"]\n numpy[\"numpy<br>1.26.1\"]\n packaging[\"packaging<br>24.1\"]\n pandas[\"pandas<br>2.2.3\"]\n pillow[\"Pillow<br>10.1.0\"]\n pyparsing[\"pyparsing<br>3.1.1\"]\n python-dateutil[\"python-dateutil<br>2.8.2\"]\n pytz[\"pytz<br>2023.3.post1\"]\n requests[\"requests<br>2.31.0\"]\n six[\"six<br>1.16.0\"]\n tzdata[\"tzdata<br>2023.3\"]\n urllib3[\"urllib3<br>2.0.6\"]\n contourpy -- \"≥1.23\" --> numpy\n matplotlib -- \"≥0.10\" --> cycler\n matplotlib -- \"≥1.0.1\" --> contourpy\n matplotlib -- \"≥1.0.1\" --> kiwisolver\n matplotlib -- \"≥1.21,<2\" --> numpy\n matplotlib -- \"≥2.3.1\" --> pyparsing\n matplotlib -- \"≥2.7\" --> python-dateutil\n matplotlib -- \"≥20.0\" --> packaging\n matplotlib -- \"≥4.22.0\" --> fonttools\n matplotlib -- \"≥6.2.0\" --> pillow\n pandas -- \"≥1.26.0\" --> numpy\n pandas -- \"≥2.8.2\" --> python-dateutil\n pandas -- \"≥2020.1\" --> pytz\n pandas -- \"≥2022.7\" --> tzdata\n python-dateutil -- \"≥1.5\" --> six\n requests -- \"≥1.21.1,<3\" --> urllib3\n requests -- \"≥2,<4\" --> charset-normalizer\n requests -- \"≥2.5,<4\" --> idna\n requests -- \"≥2017.4.17\" --> certifi\n\n```\n\n## Fresh install\n\n```bash\npip install ehyd-tools\n```\n\nAdd the following tags to the command for special options:\n\n- ```--user```: To install the package only for the local user account (no admin rights needed)\n- ```--upgrade```: To update the package\n\n# Alternative Repositories\n\n- https://github.com/hydrogeology-graz/ehyd\n- https://github.com/joha1/ehyd_reader\n\n# Usage for general time-series data\n\n### Examples Jupyter notebooks for Extended python API\n\n> links only work on GitHub!\n\n- [the design rainfall](example/example_design_rainfall.ipynb)\n- [model rain creator](example/example_synthetic_rain.ipynb)\n- [the general data-reader](example/example_python_api_general.ipynb)\n- [the gis extract](example/example_gis_export.ipynb)\n\n# Usage for high-res precipitation time-series\n\nTo start the script use following commands in the terminal/Prompt\n\n```ehyd_tools```\n\n## Commandline tool \n\nWith the `-h` (help) flag you can see the complete functionality of the tool.\n\n```bash\nehyd_tools -h\n```\n\n> ```\n> usage: __main__.py [-h] [-id ID] [--input INPUT] [--max10a] [--start START]\n> [--end END] [--add_gaps] [--to_csv] [--to_parquet] [--plot]\n> [--statistics] [--meta] [--unix]\n> \n> optional arguments:\n> -h, --help show this help message and exit\n> -id ID the id number for the station from the ehyd.gv.at platform\n> --input INPUT path to the rain input file including the filename\n> --max10a consider only 10 years with the most availability (for\n> clipping the data)\n> --start START custom start time (Format=\"YYYY-MM-DD\") for clipping the data\n> --end END custom end time (Format=\"YYYY-MM-DD\") for clipping the data\n> --add_gaps save a gaps-table as a csv-file\n> --to_csv save the time-series as csv-file (to the current directory if\n> the id is used or in the directory of the input-file)\n> --to_parquet save the time-series as parquet-file (to the current\n> directory if the id is used or in the directory of the input-\n> file) - parquet is a much faster as csv to read and write\n> --plot save a bar-plot with monthly sums and availability as a png-\n> file\n> --statistics save the basic statistics (sum, max & min) as a txt-file\n> --meta save the meta-data presented in ehyd as a txt-file\n> --unix export the csv files with a \",\" as separator and a \".\" as\n> decimal sign (otherwise \";\" as separator and a \",\" as decimal\n> sign will be used)\n> ```\n\n## The high-res precipitation stations\n\n> links only work on GitHub!\n\n[List of ehyd-stations with the id-number and the label](ehyd_tools/ehyd_stations.json)\n\n## Examples\n\n> links only work on GitHub!\n\n[Example Jupyter notebook for the commandline](example/example_commandline.ipynb)\n\n[Example Jupyter notebook for the python api](example/example_python_api.ipynb)\n\n[Example python skript](example/example_python_api.py)\n\n### Example results files\n\n> links only work on GitHub!\n\n[Data-gaps in the series](example/ehyd_112086_gaps.csv)\n\n[Meta-data of the series](example/ehyd_112086_meta.txt)\n\n\n### Example Plot\n\n> links only work on GitHub!\n\n![Regenh\u00f6henlinien](example/ehyd_112086_plot.png)\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "Reading and analyzing hydro(geo)logic time series from the Austrian government's \"ehyd.gv.at\" platform.",
"version": "0.1.7",
"project_urls": {
"Changelog": "https://github.com/MarkusPic/ehyd_tools/blob/master/CHANGELOG.md",
"homepage": "https://github.com/MarkusPic/ehyd_tools"
},
"split_keywords": [
"austria",
" precipitation",
" groundwater",
" hydrology",
" data",
" environment",
" civil_engineering",
" api"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "093a6ad228b538f49d27a449ca1e15d2f137290df59c731534ff982ff6fbc50c",
"md5": "f192c07a4b02a91cbc4e0770a2e9ab97",
"sha256": "cee873a2db688742f4d2e13bf9c3097d1a3e60dfd73ccf0baa2791d271582dff"
},
"downloads": -1,
"filename": "ehyd_tools-0.1.7-py3-none-any.whl",
"has_sig": false,
"md5_digest": "f192c07a4b02a91cbc4e0770a2e9ab97",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.7",
"size": 86851,
"upload_time": "2024-12-08T22:00:26",
"upload_time_iso_8601": "2024-12-08T22:00:26.200720Z",
"url": "https://files.pythonhosted.org/packages/09/3a/6ad228b538f49d27a449ca1e15d2f137290df59c731534ff982ff6fbc50c/ehyd_tools-0.1.7-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "d429b9a5631b025cfa2c884adbbf76390d2c85ba5a67627d7cf852192a0c8424",
"md5": "f39c0ddd1dcd4e85684cb8d1dfd71095",
"sha256": "de65a9dacadc1612f318076c73895863fb76d666fee5dfd9457d9a158a61b76f"
},
"downloads": -1,
"filename": "ehyd_tools-0.1.7.tar.gz",
"has_sig": false,
"md5_digest": "f39c0ddd1dcd4e85684cb8d1dfd71095",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.7",
"size": 84944,
"upload_time": "2024-12-08T22:00:28",
"upload_time_iso_8601": "2024-12-08T22:00:28.172247Z",
"url": "https://files.pythonhosted.org/packages/d4/29/b9a5631b025cfa2c884adbbf76390d2c85ba5a67627d7cf852192a0c8424/ehyd_tools-0.1.7.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-08 22:00:28",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "MarkusPic",
"github_project": "ehyd_tools",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"requirements": [
{
"name": "numpy",
"specs": [
[
">=",
"1.14"
]
]
},
{
"name": "pandas",
"specs": [
[
">=",
"1"
]
]
},
{
"name": "matplotlib",
"specs": [
[
">=",
"3"
]
]
},
{
"name": "requests",
"specs": []
},
{
"name": "argh",
"specs": []
}
],
"lcname": "ehyd-tools"
}