Skip to main content

Parsers for DWD's open weather data.

Project description

dwdparse

Build Status PyPI Release

Parsers for DWD's open weather data.

The DWD (Deutscher Wetterdienst), as Germany's meteorological service, publishes a myriad of meteorological observations and calculations as part of their Open Data program.

dwdparse is a Python library for parsing the various formats that this data is published in, with no dependencies outside the standard library. It serves as the parsing backend for Bright Sky.

Our development effort focuses mainly on the data that is made available through Bright Sky, although we are very open to requests or contributions regarding other parsing targets. If you are looking for a more complete set of parsers - including for data from other weather agencies - and you don't mind the extra dependencies, take a look at the excellent wetterdienst.

Looking for something specific?

I just want to retrieve some weather data

You can use the free public Bright Sky instance!

I want to parse DWD weather files or contribute to dwdparse's source code

Read on. :)

Quickstart

You can use this package both as a stand-alone command-line tool or as a Python library.

Stand-alone DWD file parsing

  1. Install the dwdparse package from PyPI:

    $ pip install dwdparse
    
  2. Call dwdparse, providing your target file (or URL) as argument:

    $ dwdparse stundenwerte_TU_01766_akt.zip
    

This will output a newline-separated list of JSON records. Note that all numerical weather data is converted to SI units. If you wish to use DWD units, or if you need both DWD and WMO station IDs, check out the --units option and the example section with dwdparse --help.

Parsing DWD files from Python code

  1. Install the dwdparse package from PyPI:

    $ pip install dwdparse
    
  2. In Python, import one of the dwdparse parsers (or the get_parser utility function) from dwdparse, then call it's parse() method with the path of the file you would like to parse. This will return an iterable over weather records:

    from brightsky import get_parser
    
    
    DWD_FILE_PATH = 'stundenwerte_TU_01766_akt.zip'
    
    parser_class = get_parser(DWD_FILE_PATH)
    parser = parser_class()
    
    for record in parser.parse(DWD_FILE_PATH):
        print(record)
    

Acknowledgements

dwdparse is developed as the main parsing core for Bright Sky. Bright Sky's development is boosted by the priceless guidance and support of the Open Knowledge Foundation's Prototype Fund program, and is generously funded by Germany's Federal Ministry of Education and Research. Obvious as it may be, it should be mentioned that none of this would be possible without the painstaking, never-ending effort of the Deutscher Wetterdienst.

Prototype Fund     Open Knowledge Foundation Germany     Bundesministerium für Bildung und Forschung     Deutscher Wetterdienst

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

dwdparse-0.9.9.tar.gz (22.3 kB view details)

Uploaded Source

Built Distribution

dwdparse-0.9.9-py3-none-any.whl (17.5 kB view details)

Uploaded Python 3

File details

Details for the file dwdparse-0.9.9.tar.gz.

File metadata

  • Download URL: dwdparse-0.9.9.tar.gz
  • Upload date:
  • Size: 22.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for dwdparse-0.9.9.tar.gz
Algorithm Hash digest
SHA256 44c33d874f0b5a07c3541f87767244019ed76e11345af06801c82cbc1125853e
MD5 203a774f93095f716ad12cd398d50d3b
BLAKE2b-256 8c90d694126173642444e869e17fb3ccdd9dc70d38c04e24e2d5a1b54b13bd38

See more details on using hashes here.

Provenance

File details

Details for the file dwdparse-0.9.9-py3-none-any.whl.

File metadata

  • Download URL: dwdparse-0.9.9-py3-none-any.whl
  • Upload date:
  • Size: 17.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for dwdparse-0.9.9-py3-none-any.whl
Algorithm Hash digest
SHA256 0ff29dfc061bb082c26e5c02a4bd707c90bd943953094c0b468bc348ac689378
MD5 e98b025b1fe2ba53121c8beaae842874
BLAKE2b-256 0555e6ffcc285417e833bbc1be76dce01944607fa6a453515ea701e78f7e8bac

See more details on using hashes here.

Provenance

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