-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathfind-closest-noaa-weather-station.py
executable file
·35 lines (29 loc) · 1.2 KB
/
find-closest-noaa-weather-station.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
#!/usr/bin/env python
#
# Reads the weather station list from http://weather.gov/xml/current_obs/index.xml
# and prints the stations sorted by distance to a given lat/long pair
#
# Usage:
#
# find-closest-noaa-weather-station.py <(curl -L http://weather.gov/xml/current_obs/index.xml) 37.7761965 -122.3947188
#
# Maintained at https://github.com/liyanage/macosx-shell-scripts
#
import sys
import math
import subprocess
import xml.etree.ElementTree
target_lat, target_lon = float(sys.argv[2]), float(sys.argv[3])
tree = xml.etree.ElementTree.parse(sys.argv[1])
station_map = {}
for station in tree.iter('station'):
lat, lon = float(station.find('latitude').text), float(station.find('longitude').text)
id = station.find('station_id').text
name = station.find('station_name').text
delta = abs(target_lat - lat) + abs(target_lon - lon)
station_data = lat, lon, id, name, delta
station_map[id] = station_data
stations_sorted = sorted(station_map.values(), cmp=lambda a, b: cmp(a[4], b[4]))
for lat, lon, id, name, delta in stations_sorted:
print '{},{}\t{}\t{}'.format(lat, lon, id, name)
# subprocess.call('curl http://w1.weather.gov/xml/current_obs/{}.xml'.format(id), shell=True)