This is an old revision of the document!
Usage: /metno/local/bin/bufrread.pl <bufr file(s)> [options]
Will print section 0-4 in BUFR messages in <bufr file(s)>.
Options (may be abbreviated, e.g. --h or -h for --help) are:
--codetables Use code and flag tables to resolve values where unit
is [CODE TABLE] or [FLAG TABLE]
--data_only Print section 4 (data section) only
--param <descriptor file>
Decode parameters with descriptors in <descriptor file> only
--filter <filter file>
Decode observations meeting criteria in <filter file> only
--bitmap Display bit mapped values on same line
--noqc Do not decode quality control
(or any descriptors following 222000)
--outfile <filename>
Will print to <filename> instead of STDOUT
--optional_section
Display a hex dump of optional section if present
--width n Set width of field used for data values to n characters
(default is 15)
--strict_checking n n=0 (default) Disable strict checking of BUFR format
n=1 Issue warning if (recoverable) error in
BUFR format
n=2 Croak if (recoverable) error in BUFR format.
Nothing more in this message will be decoded.
--all_operators Show all operator descriptors when printing section 4
--tablepath <path to BUFR tables>
Set path to BUFR tables (overrides ENV{BUFR_TABLES})
--verbose n Set verbose level to n, 0<=n<=3 (default 0)
--help Print this Usage
You should probably set
export BUFR_TABLES=/usr/local/emos/bufrtables
or use the --tablepath option.
Each line in <descriptor file> should start with a BUFR descriptor (6 digits).
Rest of line will be ignored. bufrread will extract values for these descriptors
only. If used together with --filter, <descriptor file> must contain all descriptors
in <filter file>.
Using --filter will decode only those observations that meet one of the criteria in
<filter file> (and all of those criteria marked D!). Comments (starting with #) are
ignored. An example of a filter file is
# All stations in WMO block 01
D: 001001
1
D: 001001 001002
3 895
6 252
D: 001011
LF5U # Ekofisk
D!: 004004
6
7
which decodes all observations with block number 01, two other specific wmo stations
and one specific ship, all of which having hour (004004) equal to 6 or 7.
If there is no value line after a descriptor line, it is enough that the observation
contains the descriptor(s), whatever the values are. So to extract all ship messages
from a BUFR synop file, the filter file should contain this single line only:
D: 001011
If an error occurs during decoding (typically because the required BUFR table is
missing or message is corrupt) the message is skipped, and the number of errors
is reported at end of output.