2020-01-28 14:32:34 +00:00
|
|
|
# (C) Copyright 2005- ECMWF.
|
2016-09-30 16:48:19 +00:00
|
|
|
#
|
|
|
|
# This software is licensed under the terms of the Apache Licence Version 2.0
|
|
|
|
# which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
|
|
|
|
#
|
|
|
|
# In applying this licence, ECMWF does not waive the privileges and immunities granted to it by
|
|
|
|
# virtue of its status as an intergovernmental organisation nor does it submit to any jurisdiction.
|
|
|
|
#
|
|
|
|
# Python implementation: bufr_read_tropical_cyclone
|
|
|
|
#
|
|
|
|
# Description: how to read data of the ECMWF EPS tropical cyclone tracks encoded in BUFR format.
|
|
|
|
#
|
|
|
|
|
2017-08-09 12:52:53 +00:00
|
|
|
from __future__ import print_function
|
2021-09-15 11:28:05 +00:00
|
|
|
|
2016-09-30 16:48:19 +00:00
|
|
|
import getopt
|
2021-09-15 11:28:05 +00:00
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
import traceback
|
|
|
|
|
2016-09-30 16:48:19 +00:00
|
|
|
from eccodes import *
|
|
|
|
|
2017-08-09 13:16:58 +00:00
|
|
|
VERBOSE = 1 # verbose error reporting
|
2021-09-15 19:45:34 +00:00
|
|
|
default_namespace = "ls"
|
2017-08-09 13:16:58 +00:00
|
|
|
|
2016-09-30 16:48:19 +00:00
|
|
|
|
|
|
|
def do_print(namespace, INPUT):
|
2021-09-15 19:45:34 +00:00
|
|
|
f = open(INPUT, "rb")
|
2016-09-30 16:48:19 +00:00
|
|
|
first_time = True
|
|
|
|
|
2021-09-15 19:45:34 +00:00
|
|
|
print("{")
|
2017-08-09 12:52:53 +00:00
|
|
|
print(' "messages" : [')
|
2016-09-30 16:48:19 +00:00
|
|
|
while 1:
|
|
|
|
gid = codes_grib_new_from_file(f)
|
|
|
|
if gid is None:
|
|
|
|
break
|
|
|
|
|
|
|
|
if not first_time:
|
2021-09-15 19:45:34 +00:00
|
|
|
print(" ,{")
|
2016-09-30 16:48:19 +00:00
|
|
|
else:
|
2021-09-15 19:45:34 +00:00
|
|
|
print(" {")
|
2016-09-30 16:48:19 +00:00
|
|
|
first_time = False
|
|
|
|
|
|
|
|
iterid = codes_keys_iterator_new(gid, namespace)
|
|
|
|
|
|
|
|
f1 = True
|
|
|
|
while codes_keys_iterator_next(iterid):
|
|
|
|
keyname = codes_keys_iterator_get_name(iterid)
|
2019-03-11 12:24:43 +00:00
|
|
|
keyval = codes_get_string(gid, keyname)
|
2016-09-30 16:48:19 +00:00
|
|
|
if not f1:
|
2021-09-15 19:45:34 +00:00
|
|
|
print(",")
|
2016-09-30 16:48:19 +00:00
|
|
|
else:
|
2021-09-15 19:45:34 +00:00
|
|
|
print("")
|
2016-09-30 16:48:19 +00:00
|
|
|
f1 = False
|
2021-09-15 19:45:34 +00:00
|
|
|
print(' "%s" : "%s"' % (keyname, keyval), end=" ")
|
2016-09-30 16:48:19 +00:00
|
|
|
|
2021-09-15 19:45:34 +00:00
|
|
|
print("")
|
|
|
|
print(" }")
|
2016-09-30 16:48:19 +00:00
|
|
|
codes_keys_iterator_delete(iterid)
|
|
|
|
codes_release(gid)
|
|
|
|
|
2021-09-15 19:45:34 +00:00
|
|
|
print(" ]")
|
|
|
|
print("}")
|
2016-09-30 16:48:19 +00:00
|
|
|
f.close()
|
|
|
|
|
2017-08-09 13:16:58 +00:00
|
|
|
|
2016-09-30 16:48:19 +00:00
|
|
|
def usage():
|
|
|
|
progname = os.path.basename(sys.argv[0])
|
2017-08-09 12:52:53 +00:00
|
|
|
print("Usage: ", progname, "[options] grib_file1 grib_file2 ...")
|
2021-09-15 19:45:34 +00:00
|
|
|
print("Options:")
|
|
|
|
print("\t-n namespace")
|
|
|
|
print("\t\tAll the keys belonging to namespace are printed.")
|
|
|
|
print("\t-m Mars keys are printed.")
|
|
|
|
print("")
|
2016-09-30 16:48:19 +00:00
|
|
|
|
2017-08-09 13:16:58 +00:00
|
|
|
|
2016-09-30 16:48:19 +00:00
|
|
|
def main():
|
|
|
|
if len(sys.argv) < 2:
|
|
|
|
usage()
|
|
|
|
return 1
|
|
|
|
try:
|
|
|
|
options = "mn:"
|
|
|
|
namespace = default_namespace
|
|
|
|
opts, args = getopt.getopt(sys.argv[1:], options)
|
|
|
|
for o, a in opts:
|
2021-09-15 19:45:34 +00:00
|
|
|
if o == "-m":
|
|
|
|
namespace = "mars"
|
|
|
|
elif o == "-n":
|
2016-09-30 16:48:19 +00:00
|
|
|
namespace = a or default_namespace
|
|
|
|
else:
|
2021-09-15 19:45:34 +00:00
|
|
|
assert False, "Invalid option"
|
2016-09-30 16:48:19 +00:00
|
|
|
|
|
|
|
# Check we have some GRIB files to process
|
|
|
|
if not args:
|
|
|
|
usage()
|
|
|
|
return 1
|
|
|
|
for arg in args:
|
|
|
|
do_print(namespace, arg)
|
|
|
|
except getopt.GetoptError as err:
|
2021-09-15 19:45:34 +00:00
|
|
|
print("Error: ", err)
|
2016-09-30 16:48:19 +00:00
|
|
|
usage()
|
|
|
|
return 1
|
2022-05-10 14:07:56 +00:00
|
|
|
except CodesInternalError as err:
|
2016-09-30 16:48:19 +00:00
|
|
|
if VERBOSE:
|
|
|
|
traceback.print_exc(file=sys.stderr)
|
|
|
|
else:
|
2017-08-09 12:52:53 +00:00
|
|
|
print(err.msg, file=sys.stderr)
|
2016-09-30 16:48:19 +00:00
|
|
|
|
|
|
|
return 1
|
|
|
|
|
2017-08-09 13:16:58 +00:00
|
|
|
|
2016-09-30 16:48:19 +00:00
|
|
|
if __name__ == "__main__":
|
|
|
|
sys.exit(main())
|