Changeset 587 in lmdz_wrf for trunk/tools


Ignore:
Timestamp:
Jul 8, 2015, 7:06:26 PM (10 years ago)
Author:
lfita
Message:

Adding `rmchar'; rmchar,[val],[pos], remove [val] characters from [pos]='B', beginning, 'E', end as operation

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/tools/create_OBSnetcdf.py

    r553 r587  
    122122      varTYPE='|' list of variable types ('D', 'F', 'I', 'I64', 'S')
    123123      varOPER='|' list of operations to do to the variables to meet their units ([oper],[val])
    124         [oper]=-,sumc,subc,mulc,divc (nothing, add, rest, multiply and divide)
    125 
     124        [oper]:
     125          -, nothing
     126          sumc, add [val]
     127          subc, rest [val]
     128          mulc, multiply by [val]
     129          divc, divide by [val]
     130          rmchar,[val],[pos], remove [val] characters from [pos]='B', beginning, 'E', end
    126131      NAMElon=name of the variable with the longitude (x position)
    127132      NAMElat=name of the variable with the latitude (y position)
     
    202207    fname = 'value_fmt'
    203208
    204     aopers = ['sumc','subc','mulc','divc']
     209    aopers = ['sumc','subc','mulc','divc', 'rmchar']
    205210
    206211    fmts = ['D', 'F', 'I', 'I64', 'S']
     
    211216            newval = None
    212217        else:
    213             print 'op:',op
     218            print 'op: **' + op + '**'
    214219            if op != '-':
    215220                opern = op.split(',')[0]
    216                 operv = np.float(op.split(',')[1])
     221                operv = op.split(',')[1]
    217222
    218223                if not searchInlist(aopers,opern):
     
    223228            else:
    224229                opern = 'sumc'
    225                 operv = 0.
     230                operv = '0.'
    226231
    227232            if not searchInlist(fmts, fmt):
     
    236241                    elif opern == 'mulc': newval = np.float32(val) * opv
    237242                    elif opern == 'divc': newval = np.float32(val) / opv
     243                    elif opern == 'rmchar':
     244                        opv = int(operv)
     245                        Lval = len(val)
     246                        if op.split(',')[2] == 'B':
     247                            newval = np.float32(val[opv:Lval+1])
     248                        elif op.split(',')[2] == 'E':
     249                            newval = np.float32(val[Lval-opv:Lval])
     250                        else:
     251                            print errormsg
     252                            print '  ' + fname + ": operation '" + opern + "' not " +\
     253                              " work with '" + op.split(',')[2] + "' !!"
     254                            quit(-1)
    238255                elif fmt == 'F':
    239256                    opv = np.float(operv)
     
    242259                    elif opern == 'mulc': newval = np.float(val) * opv
    243260                    elif opern == 'divc': newval = np.float(val) / opv
     261                    elif opern == 'rmchar':
     262                        opv = int(operv)
     263                        Lval = len(val)
     264                        if op.split(',')[2] == 'B':
     265                            newval = np.float(val[opv:Lval+1])
     266                        elif op.split(',')[2] == 'E':
     267                            newval = np.float(val[0:Lval-opv])
     268                        else:
     269                            print errormsg
     270                            print '  ' + fname + ": operation '" + opern + "' not " +\
     271                              " work with '" + op.split(',')[2] + "' !!"
     272                            quit(-1)
     273
    244274                elif fmt == 'I':
    245275                    opv = int(operv)
     
    248278                    elif opern == 'mulc': newval = int(val) * opv
    249279                    elif opern == 'divc': newval = int(val) / opv
     280                    elif opern == 'rmchar':
     281                        opv = int(operv)
     282                        Lval = len(val)
     283                        if op.split(',')[2] == 'B':
     284                            newval = int(val[opv:Lval+1])
     285                        elif op.split(',')[2] == 'E':
     286                            newval = int(val[0:Lval-opv])
     287                        else:
     288                            print errormsg
     289                            print '  ' + fname + ": operation '" + opern + "' not " +\
     290                              " work with '" + op.split(',')[2] + "' !!"
     291                            quit(-1)
    250292                elif fmt == 'I64':
    251293                    opv = np.int64(operv)
     
    254296                    elif opern == 'mulc': newval = np.int64(val) * opv
    255297                    elif opern == 'divc': newval = np.int64(val) / opv
     298                    elif opern == 'rmchar':
     299                        opv = int(operv)
     300                        Lval = len(val)
     301                        if op.split(',')[2] == 'B':
     302                            newval = np.int64(val[opv:Lval+1])
     303                        elif op.split(',')[2] == 'E':
     304                            newval = np.int64(val[0:Lval-opv])
     305                        else:
     306                            print errormsg
     307                            print '  ' + fname + ": operation '" + opern + "' not " +\
     308                              " work with '" + op.split(',')[2] + "' !!"
     309                            quit(-1)
    256310                elif fmt == 'S':
    257                     newval = val
     311                    if opern == 'rmchar':
     312                        opv = int(operv)
     313                        Lval = len(val)
     314                        if op.split(',')[2] == 'B':
     315                            newval = val[opv:Lval+1]
     316                        elif op.split(',')[2] == 'E':
     317                            newval = val[0:Lval-opv]
     318                        else:
     319                            print errormsg
     320                            print '  ' + fname + ": operation '" + opern + "' not " +\
     321                              " work with '" + op.split(',')[2] + "' !!"
     322                            quit(-1)
     323                    else:
     324                        newval = val
     325
    258326    else:
    259327        newval = None
     
    886954        print '      excess of formats for:', formats[Nshow:len(formats)+1]
    887955
    888     quit(-1)
     956#    quit(-1)
    889957
    890958# Reading values
Note: See TracChangeset for help on using the changeset viewer.