ehyd-tools


Nameehyd-tools JSON
Version 0.1.7 PyPI version JSON
download
home_pageNone
SummaryReading and analyzing hydro(geo)logic time series from the Austrian government's "ehyd.gv.at" platform.
upload_time2024-12-08 22:00:28
maintainerNone
docs_urlNone
authorNone
requires_python>=3.7
licenseMIT
keywords austria precipitation groundwater hydrology data environment civil_engineering api
VCS
bugtrack_url
requirements numpy pandas matplotlib requests argh
Travis-CI No Travis.
coveralls test coverage No coveralls.
            © [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 -- "&ge;1.23" --> numpy
    matplotlib -- "&ge;0.10" --> cycler
    matplotlib -- "&ge;1.0.1" --> contourpy
    matplotlib -- "&ge;1.0.1" --> kiwisolver
    matplotlib -- "&ge;1.21,&lt;2" --> numpy
    matplotlib -- "&ge;2.3.1" --> pyparsing
    matplotlib -- "&ge;2.7" --> python-dateutil
    matplotlib -- "&ge;20.0" --> packaging
    matplotlib -- "&ge;4.22.0" --> fonttools
    matplotlib -- "&ge;6.2.0" --> pillow
    pandas -- "&ge;1.26.0" --> numpy
    pandas -- "&ge;2.8.2" --> python-dateutil
    pandas -- "&ge;2020.1" --> pytz
    pandas -- "&ge;2022.7" --> tzdata
    python-dateutil -- "&ge;1.5" --> six
    requests -- "&ge;1.21.1,&lt;3" --> urllib3
    requests -- "&ge;2,&lt;4" --> charset-normalizer
    requests -- "&ge;2.5,&lt;4" --> idna
    requests -- "&ge;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 -- \"&ge;1.23\" --> numpy\n    matplotlib -- \"&ge;0.10\" --> cycler\n    matplotlib -- \"&ge;1.0.1\" --> contourpy\n    matplotlib -- \"&ge;1.0.1\" --> kiwisolver\n    matplotlib -- \"&ge;1.21,&lt;2\" --> numpy\n    matplotlib -- \"&ge;2.3.1\" --> pyparsing\n    matplotlib -- \"&ge;2.7\" --> python-dateutil\n    matplotlib -- \"&ge;20.0\" --> packaging\n    matplotlib -- \"&ge;4.22.0\" --> fonttools\n    matplotlib -- \"&ge;6.2.0\" --> pillow\n    pandas -- \"&ge;1.26.0\" --> numpy\n    pandas -- \"&ge;2.8.2\" --> python-dateutil\n    pandas -- \"&ge;2020.1\" --> pytz\n    pandas -- \"&ge;2022.7\" --> tzdata\n    python-dateutil -- \"&ge;1.5\" --> six\n    requests -- \"&ge;1.21.1,&lt;3\" --> urllib3\n    requests -- \"&ge;2,&lt;4\" --> charset-normalizer\n    requests -- \"&ge;2.5,&lt;4\" --> idna\n    requests -- \"&ge;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"
}
        
Elapsed time: 0.73517s