Tabs Page |
---|
|
Code Block |
---|
language | none |
---|
title | grib_get_keys.f90 |
---|
linenumbers | false |
---|
| ! (C) Copyright 2005-2016 ECMWF.
!
! 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.
!
!
! Description: how to get values using keys from GRIB messages
!
!
program grib_get_keys
use eccodes
implicit none
integer :: ifile
integer :: iret
integer :: igrib
real :: latitudeOfFirstPointInDegrees
real :: longitudeOfFirstPointInDegrees
real :: latitudeOfLastPointInDegrees
real :: longitudeOfLastPointInDegrees
integer :: numberOfPointsAlongAParallel
integer :: numberOfPointsAlongAMeridian
real, dimension(:), allocatable :: values
integer :: numberOfValues
real :: average,min_val, max_val
integer :: is_missing
character(len=10) :: open_mode='r'
call codes_open_file(ifile, &
'../../data/reduced_latlon_surface.grib1', open_mode)
! Loop on all the messages in a file.
! A new GRIB message is loaded from file
! igrib is the grib id to be used in subsequent calls
call codes_grib_new_from_file(ifile,igrib, iret)
LOOP: DO WHILE (iret /= CODES_END_OF_FILE)
! For debugging
call grib_dump(igrib)
! Check if the value of the key is MISSING
is_missing=0;
call codes_is_missing(igrib,'Ni',is_missing);
if ( is_missing /= 1 ) then
! Key value is not missing so get as an integer
call codes_get(igrib,'Ni',numberOfPointsAlongAParallel)
write(*,*) 'numberOfPointsAlongAParallel=', &
numberOfPointsAlongAParallel
else
write(*,*) 'numberOfPointsAlongAParallel is missing'
endif
! Get as aan integer
call codes_get(igrib,'Nj',numberOfPointsAlongAMeridian)
write(*,*) 'numberOfPointsAlongAMeridian=', &
numberOfPointsAlongAMeridian
! Get as a real
call codes_get(igrib, 'latitudeOfFirstGridPointInDegrees', &
latitudeOfFirstPointInDegrees)
write(*,*) 'latitudeOfFirstGridPointInDegrees=', &
latitudeOfFirstPointInDegrees
! Get as a real
call codes_get(igrib, 'longitudeOfFirstGridPointInDegrees', &
longitudeOfFirstPointInDegrees)
write(*,*) 'longitudeOfFirstGridPointInDegrees=', &
longitudeOfFirstPointInDegrees
! Get as a real
call codes_get(igrib, 'latitudeOfLastGridPointInDegrees', &
latitudeOfLastPointInDegrees)
write(*,*) 'latitudeOfLastGridPointInDegrees=', &
latitudeOfLastPointInDegrees
! Get as a real
call codes_get(igrib, 'longitudeOfLastGridPointInDegrees', &
longitudeOfLastPointInDegrees)
write(*,*) 'longitudeOfLastGridPointInDegrees=', &
longitudeOfLastPointInDegrees
! Get the size of the values array
call codes_get_size(igrib,'values',numberOfValues)
write(*,*) 'numberOfValues=',numberOfValues
allocate(values(numberOfValues), stat=iret)
! Get data values
call codes_get(igrib,'values',values)
call codes_get(igrib,'min',min_val) ! can also be obtained through minval(values)
call codes_get(igrib,'max',max_val) ! can also be obtained through maxval(values)
call codes_get(igrib,'average',average) ! can also be obtained through maxval(values)
deallocate(values)
write(*,*)'There are ',numberOfValues, &
' average is ',average, &
' min is ', min_val, &
' max is ', max_val
call codes_release(igrib)
call codes_grib_new_from_file(ifile,igrib, iret)
end do LOOP
call codes_close_file(ifile)
end program grib_get_keys
|
|
Tabs Page |
---|
|
Code Block |
---|
language | python |
---|
title | grib_get_keys.py |
---|
linenumbers | false |
---|
| # (C) Copyright 2005-2016 ECMWF.
#
# 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.
import traceback
import sys
from eccodes import *
INPUT = '../../data/reduced_latlon_surface.grib1'
VERBOSE = 1 # verbose error reporting
def example():
f = open(INPUT, 'rb')
keys = [
'Ni',
'Nj',
'latitudeOfFirstGridPointInDegrees',
'longitudeOfFirstGridPointInDegrees',
'latitudeOfLastGridPointInDegrees',
'longitudeOfLastGridPointInDegrees',
]
while 1:
gid = codes_grib_new_from_file(f)
if gid is None:
break
for key in keys:
try:
print (' %s: %s' % (key, codes_get(gid, key)))
except CodesInternalErrorKeyValueNotFoundError as err:
# printFull 'Errorlist with key="%s" : %s' % (key, err.msg)
of exceptions here:
print 'There are %d values, average is %f, min# is %f, max is %f' % ( https://confluence.ecmwf.int/display/ECC/Python+exception+classes
codes_get_size(gid, 'values'),
print(' Key="%s" was not found: %s' % codes_get(gidkey, 'average'),
err.msg))
codes_get(gid, 'min'),except CodesInternalError as err:
codes_get(gid, 'max')
print('Error with key="%s" : %s' % (key, err.msg))
codes_release(gid)
f.close()
def main():
try:
example()print('There are %d values, average is %f, min is %f, max is %f' % (
except CodesInternalError as err:
if VERBOSE:codes_get_size(gid, 'values'),
traceback.printcodes_exc(file=sys.stderr)
get(gid, 'average'),
else: codes_get(gid, 'min'),
sys.stderr.write(err.msg + '\n')
codes_get(gid, 'max')
return 1))
if __name__ == "__main__": codes_release(gid)
sysf.exit(main())
close()
def main():
try:
example()
except CodesInternalError as err:
if VERBOSE:
traceback.print_exc(file=sys.stderr)
else:
sys.stderr.write(err.msg + '\n')
return 1
if __name__ == "__main__":
sys.exit(main())
|
|
Tabs Page |
---|
|
Code Block |
---|
language | cpp |
---|
title | grib_get_keys.c |
---|
linenumbers | false |
---|
| /*
* (C) Copyright 2005- ECMWF.
*
* 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.
*/
/*
* C Implementation: grib_get_keys
*
* Description: how to get values using keys from GRIB messages
*
*/
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include "eccodes.h"
int main(int argc, char** argv)
{
int err = 0;
double *values = NULL;
size_t values_len= 0;
size_t i = 0, len = 0;
double latitudeOfFirstGridPointInDegrees;
double longitudeOfFirstGridPointInDegrees;
double latitudeOfLastGridPointInDegrees;
double longitudeOfLastGridPointInDegrees;
double jDirectionIncrementInDegrees;
double iDirectionIncrementInDegrees;
long numberOfPointsAlongAParallel;
long numberOfPointsAlongAMeridian;
double average |
| Tabs Page |
---|
| Code Block |
---|
language | cpp |
---|
title | grib_get_keys.c |
---|
linenumbers | false |
---|
| /*
* Copyright 2005-2016 ECMWF.
*
* 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.
*/
/*
* C Implementation: grib_get_keys
*
* Description: how to get values using keys from GRIB messages
*
*/
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include "eccodes.h"
int main(int argc, char** argv)
{
int err = 0;
doublechar* *valuespackingType = NULL;
size_t values_lenFILE* in = 0NULL;
size_t i = 0, len = 0;
double latitudeOfFirstGridPointInDegrees;
double longitudeOfFirstGridPointInDegreesconst char* filename = "../../data/regular_latlon_surface.grib1";
codes_handle *h = NULL;
in = fopen(filename,"r");
double latitudeOfLastGridPointInDegrees;if(!in) {
double longitudeOfLastGridPointInDegrees;
printf("ERROR: doubleunable jDirectionIncrementInDegrees;
to open double iDirectionIncrementInDegrees;
file %s\n",filename);
long numberOfPointsAlongAParallel;
return long numberOfPointsAlongAMeridian1;
double average = 0;}
char/* packingTypecreate = NULL;
FILE*new handle from the first message in = NULL;the file*/
consth char* filename = "../../data/regular_latlon_surface.grib1"= codes_handle_new_from_file(0, in, PRODUCT_GRIB, &err);
codes_handleif *(h == NULL;
) {
in = fopenprintf(filename,"r""Error: unable to create handle from file %s\n",filename);
if(!in) {return 1;
}
fclose(in);
/* Store the printf("ERROR: unable to open file %s\n",filename);
filename in the key "file" for this handle */
len return 1= strlen(filename);
}
/* create new handle from the first message in the fileCODES_CHECK(codes_set_string(h, "file", filename, &len), 0);
/* get as a long*/
h = CODES_CHECK(codes_handle_new_from_file(0, in, PRODUCT_GRIB, &err);
if (h == NULL) {
get_long(h,"Ni",&numberOfPointsAlongAParallel),0);
printf("Error: unable to create handle from file %snumberOfPointsAlongAParallel=%ld\n",filenamenumberOfPointsAlongAParallel);
/* get as return 1;a long*/
}CODES_CHECK(codes_get_long(h,"Nj",&numberOfPointsAlongAMeridian),0);
fclose(in printf("numberOfPointsAlongAMeridian=%ld\n",numberOfPointsAlongAMeridian);
/* get Storeas the filename in the key "file" for this handle */
len = strlen(filename);a double*/
CODES_CHECK(codes_get_double(h,"latitudeOfFirstGridPointInDegrees",&latitudeOfFirstGridPointInDegrees),0);
printf("latitudeOfFirstGridPointInDegrees=%g\n",latitudeOfFirstGridPointInDegrees);
/* get as a double*/
CODES_CHECK(codes_setget_stringdouble(h, "filelongitudeOfFirstGridPointInDegrees", filename, &lenlongitudeOfFirstGridPointInDegrees), 00);
printf("longitudeOfFirstGridPointInDegrees=%g\n",longitudeOfFirstGridPointInDegrees);
/* get as a longdouble*/
CODES_CHECK(codes_get_longdouble(h,"NilatitudeOfLastGridPointInDegrees",&numberOfPointsAlongAParallellatitudeOfLastGridPointInDegrees),0);
printf("numberOfPointsAlongAParallellatitudeOfLastGridPointInDegrees=%ld%g\n",numberOfPointsAlongAParallellatitudeOfLastGridPointInDegrees);
/* get as a longdouble*/
CODES_CHECK(codes_get_longdouble(h,"NjlongitudeOfLastGridPointInDegrees",&numberOfPointsAlongAMeridianlongitudeOfLastGridPointInDegrees),0);
printf("numberOfPointsAlongAMeridianlongitudeOfLastGridPointInDegrees=%ld%g\n",numberOfPointsAlongAMeridianlongitudeOfLastGridPointInDegrees);
/* get as a double*/
CODES_CHECK(codes_get_double(h,"latitudeOfFirstGridPointInDegreesjDirectionIncrementInDegrees",&latitudeOfFirstGridPointInDegreesjDirectionIncrementInDegrees),0);
printf("latitudeOfFirstGridPointInDegreesjDirectionIncrementInDegrees=%g\n",latitudeOfFirstGridPointInDegreesjDirectionIncrementInDegrees);
/* get as a double*/
CODES_CHECK(codes_get_double(h,"longitudeOfFirstGridPointInDegreesiDirectionIncrementInDegrees",&longitudeOfFirstGridPointInDegreesiDirectionIncrementInDegrees),0);
printf("longitudeOfFirstGridPointInDegreesiDirectionIncrementInDegrees=%g\n",longitudeOfFirstGridPointInDegreesiDirectionIncrementInDegrees);
/* get as astring double*/
CODES_CHECK(codes_get_doublelength(h, "latitudeOfLastGridPointInDegreespackingType", &latitudeOfLastGridPointInDegreeslen), 0);
packingType printf("latitudeOfLastGridPointInDegrees=%g\n",latitudeOfLastGridPointInDegrees);
/* get as a double*/ (char*)malloc(len*sizeof(char));
CODES_CHECK(codes_get_doublestring(h, "longitudeOfLastGridPointInDegreespackingType",&longitudeOfLastGridPointInDegrees),0 packingType, &len);
printf("longitudeOfLastGridPointInDegreespackingType=%g%s\n",longitudeOfLastGridPointInDegrees packingType);
free(packingType);
/* get as a double the size of the values array*/
CODES_CHECK(codes_get_doublesize(h,"jDirectionIncrementInDegreesvalues",&jDirectionIncrementInDegreesvalues_len),0);
printf("jDirectionIncrementInDegrees=%g\n",jDirectionIncrementInDegreesvalues = (double*)malloc(values_len*sizeof(double));
/* get asdata a doublevalues*/
CODES_CHECK(codes_get_double_array(h,"iDirectionIncrementInDegreesvalues",values,&iDirectionIncrementInDegrees),0);values_len),0);
average = 0;
for(i = 0; i < values_len; i++)
printf("iDirectionIncrementInDegrees=%g\n",iDirectionIncrementInDegrees) average += values[i];
/* get as string */average /=(double)values_len;
CODES_CHECK(codes_get_length(h, "packingType", &len), 0);
packingType = (char*)malloc(len*sizeof(char));
codes_get_string(h, "packingType", packingType, &len);
printf("packingType=%s\n", packingType)free(values);
printf("There are %d values, average is %g\n",(int)values_len,average);
{
int eq = 0;
free(packingType);
/* getNow retrieve the sizevalue of the valueskey "file" array*/
CODES_CHECK(codes_get_size(h,"values",&values_len),0);
valueschar = (double*)malloc(values_len*sizeof(double));
file[256]={0,};
/* get data values*/
CODES_CHECK(codes_get_double_arraylength(h, "valuesfile",values, &values_len),0);
average = 0;
for(i = 0; i < values_len; i++));
averageassert(len +== values[i];
1+strlen(filename));
average /=(double)values_len;
free(values);
codes_get_string(h, "file", file, &len);
printf("There are %d values, averageeq is %g\n",(int)values_len,average= strcmp(file, filename);
{
if (eq != int eq = 0;0) assert(!"file and filename not equal");
}
{
/* Now retrieve the/* valueExample of thegetting keybytes "file" */
const char file[256]={0,}* name = "reservedNeedNotBePresent";
CODES_CHECK(codes_get_length(h, "file", &len),0);
unsigned char* byte_val = NULL ;
assert(len == 1+strlen(filename))size_t keySize = 0;
CODES_CHECK(codes_get_string(h, "file"size(h, filename, &lenkeySize), 0);
eqbyte_val = strcmp(file, filenameunsigned char*)malloc(keySize*sizeof(char));
if (eq != 0) assert(!"file and filename not equal"GRIB_CHECK(codes_get_bytes(h, name, byte_val, &keySize), name);
}
codes_handle_delete(h);
return 0;
}
|
|
|