Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

List content of BUFR files printing values of some header keys. Only scalar keys can be printed. It does not fail when a key is not found.

USAGE

bufr_ls [options] bufr_file bufr_file ...

OPTIONS

...

Declaration of keys to print. For each key a string (key:s) or , a double (key:d) or a long an integer (key:li) type can be requested. Default type is string.

...

C style format for floating-point values.

...

As -p adding the declared keys to the default list.

...

Where clause. Messages are processed only if they match all the key/value constraints. A valid constraint is of type key=value or key!=value. For each key a string (key:s) or , a double (key:d) or a long an integer (key:li) type can be specified. Default type is string.

...

Order by. The output will be ordered according to the order by directive. Order by example: "step asc, centre desc" (step ascending and centre descending) In the value you can also use the forward-slash character '/' to specify an OR condition (i.e. a logical disjunction) Note: only one -w clause is allowed.

...

Key/values to set. For each key a string (key:s) or , a double (key:d) or a long an integer (key:li) type can be defined. By default the native type is set.

...

bufr_ls examples

  1. Without options a default list of keys is printed. The default list is can be different depending on the type of bufr BUFR message.

    Code Block
     
    >  bufr_ls ../data/bufr/syno_*multi.bufr 
    
    The result is:
    Code Block
     
    ../data/bufr/syno_multi.bufr
    masterTablesVersionNumbercentre  localTablesVersionNumber   rdbType                masterTablesVersionNumber    rdbSubtypelocalTablesVersionNumber                 rdbtimeYear                rdbtimeMonth               typicalDate                typicalTime                numberOfSubsetsrdbType            localLatitude        rdbSubtype      localLongitude           rdbtimeDate  
    13              rdbtimeTime           1     numberOfSubsets            localLatitude         1     localLongitude             
    ecmf        1                 13         2009                       1                          20090124                   120000                     1                          70.931                      -8.67    20090124                 
    13    121435                     1                          170.93                      -8.67    1                 
    ecmf         2009                       1                          2009012413                    120000                     1                          7720090124                         15.5     120000                 
    13                         1                          1                          120090124                          2009  121435                     1                          2009012477                   120000                     1                          78.9215.5                      11.93   
    ecmf                  
    3 of 3 messages in ../data/bufr/syno_multi.bufr
    
    ../data/bufr/temp_101.bufr
    13                         1                          520090124                   120000       101              1          2012                1       10                   20090124      20121030                 121435  000000                     1                          6078.7792                      -161.8311.93                     
    13 of 13 messages in ../data/bufr/tempsyno_101multi.bufr
    
    43 of 43 total messages in 21 files
    
    To print offset and count number in file use the keys offset and count. Also the total count in a


  2. It is allowed to use wildcards in filenames. set of files is available as countTotal

    Code Block
     
    >  > bufr_ls  -p offset,count,countTotal ../data/bufr/syno_*.bufr
    ../data/bufr/syno_1.bufr
    offset      count       countTotal  
    0           1           1          
    1 of 1 messages in ../data/bufr/syno_1.bufr
    
    ../data/bufr/syno_2.bufr
    0           2           2          
    1 of 1 messages in ../data/bufr/syno_2.bufr
    
    ../data/bufr/syno_3.bufr
    0           3           3          
    1 of 1 messages in ../data/bufr/syno_3.bufr
    
     
    


  3. To list only a specific set of keys use the -p option.

    Code Block
     
    >  bufr_ls -p totalLength,bufrHeaderCentre,bufrHeaderSubCentre ../data/bufr/syno_4.bufr
    0           4           4          
    1 of 1 messages in ../data/bufr/syno_4.bufr
    
    ../data/bufr/syno_multi.bufr
    0           5           5          
    220         6           6          
    440         7           7          
    3 of 3 messages in ../data/bufr/syno_multi.bufr
    
    7 of 7 total messages in 5 files
    


  4. To list only a subset of messages use the -w (where option). Only the synop 12 UTC messages are listed with the following line.

    Code Block
     
    >  bufr_ls -W 8 -w dataCategorytypicalTime=0"120000" ../data/bufr/syno_*.bufr ../data/bufr/temp_*.bufr
    


  5. All the non-synop 12 UTC messages are listed as follows:

    Code Block
     
    >   bufr_ls -W 8 -w dataCategorytypicalTime!=0"120000" ../data/bufr/syno_*.bufr
    


  6. To list only the second message from a BUFR file:

    Code Block
     
    >  bufr_ls -w count=2 ../data/bufr/tempsyno_*multi.bufr