import sys import netCDF4 from datetime import datetime ## Norwegian Meteorological Institute ## https://thredds.met.no/thredds/catalog/remotesensingradiosonde/catalog.html ## ## python3 metno_netcdf_gpx.py def print_cdf(dat): station = dat.station_name + ' (' + dat.wmo_block_and_station_number + ')' station_lat = dat.station_latitude_degrees_north * 100.0 # ? station_lon = dat.station_longitude_degrees_east * 100.0 # ? station_alt = dat.station_altitude_meter print('') print('{0} lat: {1:.5f} lon: {2:.5f} alt: {3:.1f}m'.format(station, station_lat, station_lon, station_alt) ) ts = dat.variables['time'][:].data sn = dat.variables['serial_number'][:] rs = dat.variables['sounding_system_used'][:].data # rs[]: BUFR 002011 , rs[]%100: r_ar_a 3685 tls = dat.variables['time_from_launch'][:].data N = len(ts) for n in range(N): print('{0} # SN="{1}" # type={2:d}'.format(datetime.utcfromtimestamp( ts[n] ).strftime('%Y-%m-%dT%H:%M:%SZ'), sn[n], rs[n]) ) fgpx = open("{0}.gpx".format(sn[n].replace(' ', '_')), "w") fgpx.write('\n') fgpx.write('\n') fgpx.write('station: {0}, rs_type: {1}\n'.format(station, rs[n]) ) fgpx.write('{0}\n'.format(sn[n])) lat = dat.variables['latitude'][n].data lon = dat.variables['longitude'][n].data alt = dat.variables['altitude'][n].data for k in range(len(alt)): if (alt[k] > -900.0): fgpx.write('{:.2f}'.format(lat[k], lon[k], alt[k]) ) fgpx.write('\n'.format(datetime.utcfromtimestamp( ts[n]+tls[k] ).strftime('%Y-%m-%dT%H:%M:%SZ')) ) fgpx.write('\n') fgpx.write('') fgpx.close() if len(sys.argv) < 2: sys.exit("error argv") f = sys.argv[1] data = netCDF4.Dataset(f) print_cdf(data) print('')