Versions Compared

Key

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


Excerpt
hiddentrue

In a BUFR message the same key can appear several times in different positions of the message. From ecCodes version 0.13.0 it is possible to set a key by rank and in the following bufr_filter example the 4th instance of the key airTemperature is set to the value "300.1". The value of the key is then printed

Setting keys by rank

Step-by-step guide

Setting keys by rank

  1. In a BUFR message the same key can appear several times in different positions of the message. From ecCodes version 0.13.0 it is possible to set a key by rank and in the following bufr_filter example the 4th instance of the key airTemperature is set to the value "300.1". The value of the key is then printed.

    Code Block
    languagedelphi
    titleinstructions.filter
    linenumberstrue
    set unpack=1;
    set #4#airTemperature = 300.1;
    print "#4#airTemperature=[#4#airTemperature]";
     
    set pack=1;
    write;


  2. It is very important to remember that the key is not encoded back in the data section until the key "pack" is set to 1. At line 5 the encoding is performed and at line 6 the message is written in the output file. The instruction.filters file can be used as follows

    Code Block
    languagebash
    bufr_filter -o out.bufr instructions.filter in.bufr


  3. The output file out.bufr will contain the newly encoded value of the 4th instance of the airTemperature key. If in the original message in.bufr the 4th instance of airTemperature is not present because for example there are only two airTemperature keys a "key not found" error is returned.

    Warning

    Please note: One cannot set such keys by using the "/subsetNumber=N/" notation. You must use the rank notation above.



Content by Label
showLabelsfalse
max5
spaces~usa
showSpacefalse
sortmodified
reversetrue
typepage
cqllabel = "kb-how-to-article" and type = "page" and space = "~usa"
labelskb-how-to-article