my $m = new Geo::METAR;
$m->metar("KFDY 251450Z 21012G21KT 8SM OVC065 04/M01 A3010 RMK 57014");
DESCRIPTIONMETAR reports are available on-line, thanks to the National Weather Service. Since reading the METAR format isn't easy for non-pilots, these reports are relatively useles to the common man who just wants a quick glace at the weather. This module tries to parse the METAR reports so the data can be used to create readable weather reports and/or process the data in applications.
How you might use this
Here is how you might use the Geo::METAR module.
One use that I have had for this module is to query the NWS METAR page (using the LWP modules) at:
to get an up-to-date METAR. Then, I scan thru the output, looking for what looks like a METAR string (that's not hard in Perl). Oh, EHSB can be any site location code where there is a reporting station.
I then pass the METAR into this module and get the info I want. I can then update my webcam page with the current temperature, sky conditions, or whatnot. See for yourself at http://webcam.idefix.net/
See the BUGS section for a remark about multiple passes with the same
The following functions are defined in the METAR module. Most of them are public, meaning that you're supposed to use them. Some are private, meaning that you're not supposed to use them --- but I won't stop you. Assume that functions are public unless otherwise documented.
metar() is the function to whwich you should pass a METAR string. It
will take care of decomposing it into its component parts converting
the units and so on.
Example: "$m->metar("KFDY 251450Z 21012G21KT 8SM OVC065 04/M01 A3010 RMK 57014");"
debug() toggles debugging messages. By default, debugging is turned
off. Turn it on if you are developing METAR or having trouble with
debug() understands all of the folloing:
Enable Disable ------ ------- 1 0 'yes' 'no' 'on' 'off'
If you contact me for help, I'll likely ask you for some debugging output.
dump() will dump the internal data structure for the METAR in a
semi-human readable format.
version() will print out the current version.
Example: "print $m->version;"
Called internally to break the METAR into its component tokens.
Used to make sense of the tokens found in _tokenize().
After you've called metar(), you'd probably like to get at the individual values for things like temperature, dew point, and so on. You do that by accessing individual variables via the METAR object.
This section lists those variables and what they represent.
If you call dump(), you'll find that it spits all of these out.
- The version of METAR.pm that you're using.
- The actual, raw METAR.
- Report type in English (``Routine Weather Report'' or ``Special Weather Report'')
- 4-letter site code.
- The date (just the day of the month) on which the report was issued.
- The time at which the report was issued.
- Modifier (AUTO/COR) if any.
- The current wind direction in English (Southwest, East, North, etc.)
- The current wind direction in abbreviated English (S, E, N, etc.)
- The current wind direction in degrees.
- The current wind speed in Knots.
- The current wind speed in Miles Per Hour.
- The current wind speed in Metres Per Second.
- The current wind gusting speed in Knots.
- The current wind gusting speed in Miles Per Hour.
- The current wind gusting speed in Metres Per Second.
- The wind variation in English
- The first wind variation direction
- The first wind variation direction in English
- The second wind variation direction
- The second wind variation direction in English
- Visibility information.
- Wind information.
- Runway information.
- Current weather (array)
- Current weather log (array)
- Current cloud cover (array)
- Temperature in Celsius.
- Temperature in Fahrenheit.
- Dew point in Celsius.
- Dew point in Fahrenheit.
- Hourly current temperature, fahrenheit
- Hourly current temperature, celcius
- Hourly dewpoint, fahrenheit
- Hourly dewpoint, celcius
- Altimeter setting (barometric pressure).
- Altimeter setting in hectopascals.
- Any remarks in the report.
NOTESTest suite is small and incomplete. Needs work yet.
Older versions of this module were installed as ``METAR'' instaed of ``Geo::METAR''
BUGSThe Geo::METAR is only initialized once, which means you'll get left-over crud in variables when you call the metar() function twice.
What is an invalid METAR in one country is a standard one in the next. The standard is interpreted and used by meteorologists all over the world, with local variations. This means there will always be METARs that will trip the parser.
TODOThere is a TODO file included in the Geo::METAR distribution listing the outstanding tasks that I or others have devised. Please check that list before you submit a bug report or request a new feture. It might already be on the TODO list.
AUTHORS AND COPYRIGHTCopyright 1997-2000, Jeremy D. Zawodny <Jeremy [at] Zawodny.com>
Copyright 2007, Koos van den Hout <[email protected]>
Geo::METAR is covered under the GNU Public License (GPL) version 2 or later.
The Geo::METAR Web site is located at:
CREDITSIn addition to our work on Geo::METAR, We've received ideas, help, and patches from the following folks:
* Ethan Dicks <ethan.dicks [at] gmail.com> Testing of Geo::METAR at the South Pole. Corrections and pointers to interesting cases to test. * Otterboy <jong [at] watchguard.com> Random script fixes and initial debugging help * Remi Lefebvre <remi [at] solaria.dhis.org> Debian packaging as libgeo-metar-perl.deb. * Mike Engelhart <mengelhart [at] earthtrip.com> Wind direction naming corrections. * Michael Starling <mstarling [at] logic.bm> Wind direction naming corrections. * Hans Einar Nielssen <hans.einar [at] nielssen.com> Wind direction naming corrections. * Nathan Neulinger <nneul [at] umr.edu> Lots of enhancements and corrections. Too many to list here.
RELATED PROJECTSlcdproc at http://www.lcdproc.org/ uses Geo::METAR in lcdmetar.pl to display weather data on an lcd.