Skip to content

This library downloads the NOAA weather report for a given station ID decodes it and the provides easy access to all the data found in the report.

License

Notifications You must be signed in to change notification settings

smulloni/pymetar

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1 Commit
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

pymetar - a module to fetch and parse METAR reports
---------------------------------------------------

NOTE:
During the early versions of this library, the API has changed 
considerably. In case of problems always double-check the lib
documentation of this package (librarydoc.txt).

The National Oceanic and Atmospheric Administration (NOAA,
www.noaa.gov) provides easy access to the weather reports
generated by a large number of weather stations (mostly at
airports) worldwide. Those reports are called METAR reports and
are delivered as plain text files that look like this:

Duesseldorf, Germany (EDDL) 51-18N 006-46E 41M
Jul 26, 2002 - 03:50 AM EST / 2002.07.26 0850 UTC
Wind: from the SW (220 degrees) at 9 MPH (8 KT):0
Visibility: 3 mile(s):0
Sky conditions: mostly cloudy
Weather: mist
Temperature: 60 F (16 C)
Dew Point: 57 F (14 C)
Relative Humidity: 87%
Pressure (altimeter): 30.00 in. Hg (1016 hPa)
ob: EDDL 260850Z 22008KT 5000 BR SCT006 BKN012 16/14 Q1016 BECMG BKN015
cycle: 9

While this is convenient if you just want to quickly look up the
data, there's some effort involved in parsing all of this into a
format that is digestible by a program. Plus, you have to remember
the base URL of the reports and fetch the file.

This is what this library does. All you have to do is find the
station you're interested in at
http://www.nws.noaa.gov/tg/siteloc.shtml and feed the 4-letter
station code to the MetarReport class.

On the user end, the library provides a large number of methods to
fetch the parsed information in a plethora of formats. Those
functions are described in the file librarydoc.txt which was in
turn generated using PyDoc.

As of version 0.5, pymetar uses urllib2 which in turn makes it
easy to honor the environment variable HTTP_PROXY. This simplifies
use of a proxy tremendously. Thanks go to Davide Di Blasi for both
suggesting and implementing this. The environment variable is easy
to use: just set it to:

http://username:[email protected]:port 

As of version 0.11, you can also specify a proxy (with the same
syntax) as an argument to the fetching function. This is sometimes
easier when using PyMETAR in a web application environment (such
as ZopeWeatherApplet by Jerome Alet). See librarydoc.txt for
details on how to accomplish that. 

You can also use IPs instead of hostnames, of course. When in
doubt, ask your proxy admin.

Due to some peculiarities in the METAR format, I can not rule out
the possibility that the library barfs on some less common types
of reports. If you encounter such a report, please save it and the
error messages you get as completely as possible and send them to
me at [email protected] - Thanks a lot!

Of course you may send all the other bugs you encounter to me,
too. As this is a Python library, chances are that you are Python
programmer and can provide a patch. If you do so, please, by all
means use Spaces for indentation, four per level, that makes
merging the patch a lot easier.

Enjoy the code and, as Wau Holland put it: "Viel Spass am Gerät"

About

This library downloads the NOAA weather report for a given station ID decodes it and the provides easy access to all the data found in the report.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published