Changeset 386 in lmdz_wrf for trunk/tools


Ignore:
Timestamp:
Mar 31, 2015, 10:37:35 AM (10 years ago)
Author:
lfita
Message:

Adding new operation 'file_creation' which allows to create a new file with a variable

Location:
trunk/tools
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/tools/nc_var.py

    r311 r386  
    2121  'compute_opervaralltime', 'compute_opervartimes', 'compute_tevolboxtraj',          \
    2222  'DataSetSection', 'DataSetSection_multidims', 'dimVar_creation', 'fattradd',       \
    23   'fdimadd', 'fgaddattr', 'field_stats', 'file_oper_alongdims', 'filter_2dim',       \
     23  'fdimadd', 'fgaddattr', 'field_stats', 'file_creation', 'file_oper_alongdims',     \
     24  'filter_2dim',                                                                     \
    2425  'flipdim', 'fvaradd', 'gaddattrk', 'gaddattr', 'get_namelist_vars', 'grattr',      \
    2526  'grmattr', 'igattrs', 'isgattrs', 'isvattrs', 'ivars', 'ivattrs', 'maskvar',       \
     
    7778
    7879# Operations which file name is not a real file
    79 NotCheckingFile = ['list_operations', 'netcdf_concatenation', 'netcdf_fold_concatenation']
     80NotCheckingFile = ['file_creation', 'list_operations', 'netcdf_concatenation', 'netcdf_fold_concatenation']
    8081
    8182####### ###### ##### #### ### ## #
     
    127128elif oper == 'fgaddattr':
    128129    ncvar.fgaddattr(opts.values, opts.ncfile)
     130elif oper == 'file_creation':
     131    ncvar.file_creation(opts.values, opts.ncfile, opts.varname)
    129132elif oper == 'file_oper_alongdims':
    130133    ncvar.file_oper_alongdims(opts.values, opts.ncfile, opts.varname)
  • trunk/tools/nc_var_tools.py

    r377 r386  
    1374513745#ncstepdiff('Time,Times', '/home/lluis/PY/wrfout_d01_2001-11-11_00:00:00.tests', 'Q2,T2')
    1374613746
     13747def file_creation(values, ncfile, varn):
     13748    """ Operation to create a file with one variable with a given set of dimensions
     13749      values= [dimensions]|[varattributes]|[kind]
     13750        [dimensions]: [dimn1]:[dsize1],...,[dimnN]:[dsizeN], ',' pairs of variable name [dimn] and [size]
     13751          if [dsize] = 'None', give a third value with the real size
     13752        [attributes]: [std_name]@[long_name]@[units], standard name, long name and units of the variable
     13753        [kind]: type of variable (standard netCDF4/C-like values, 'c', 'i', 'f', 'f8',...)
     13754      ncfile= name of the file
     13755      varn= name of the variables
     13756    """
     13757    fname = 'file_creation'
     13758
     13759    if values == 'h':
     13760        print fname + '_____________________________________________________________'
     13761        print file_creation.__doc__
     13762        quit()
     13763
     13764    expectargs = '[dimensions]|[varattributes]|[kind]'
     13765 
     13766    check_arguments(fname,len(expectargs.split('|')),values,'|',expectargs)
     13767
     13768    dimensions = values.split('|')[0].split(',')
     13769    attributes = values.split('|')[1]
     13770    kind = values.split('|')[2]
     13771
     13772    onc = NetCDFFile(ncfile, 'w')
     13773
     13774# Dimensions
     13775    dnames = []
     13776    dsize = []
     13777    for dim in dimensions:
     13778#        print "  Adding: '" + dim + "' ..."
     13779        dimn = dim.split(':')[0]
     13780        dimv = dim.split(':')[1]
     13781        if dimv == 'None':
     13782            if len(dim.split(':')) != 3:
     13783                print errormsg
     13784                print '  ' + fname + ": dimension '" + dimn + "' is None but the " + \
     13785                  'size is requried!!'
     13786                quit(-1)
     13787            else:
     13788                dv = None
     13789                dsize.append(int(dim.split(':')[2]))
     13790        else:
     13791            dv = int(dimv)
     13792            dsize.append(dv)
     13793
     13794        dnames.append(dimn)
     13795
     13796        newdim = onc.createDimension(dimn, dv)
     13797   
     13798    onc.sync()
     13799
     13800# Variable
     13801    if kind == 'c':
     13802        newvar = onc.createVariable(varn, 'c', tuple(dnames))
     13803#        newvar[:] = np.zeros(tuple(dsize), dtype=np.float)
     13804    if kind == 'f4':
     13805        newvar = onc.createVariable(varn, 'f4', tuple(dnames))
     13806        newvar[:] = np.zeros(tuple(dsize), dtype=np.float)
     13807    elif kind == 'f8':
     13808        newvar = onc.createVariable(varn, 'f8', tuple(dnames))
     13809        newvar[:] = np.zeros(tuple(dsize), dtype=np.float64)
     13810    elif kind == 'i':
     13811        newvar = onc.createVariable(varn, 'i', tuple(dnames))
     13812        newvar[:] = np.zeros(tuple(dsize), dtype=int)
     13813    else:
     13814        print errormsg
     13815        print '  ' + fname + ": variable kind '" + kind + "' not ready!!"
     13816        quit(-1)
     13817
     13818    sname = attributes.split('@')[0]
     13819    lname = attributes.split('@')[1]
     13820    u = attributes.split('@')[2]
     13821   
     13822    newattr = basicvardef(newvar, sname, lname, u)
     13823
     13824    onc.sync()
     13825
     13826# Global attributes
     13827    newattr = set_attribute(onc, 'description', "file creation using " + fname )
     13828    onc.sync()
     13829    onc.close()
     13830
     13831#file_creation('time_counter:12,sizes:24|time@time@seconds since 1949-12-01 00:00:00|f8', 'test.nc', 't_instant')
     13832
    1374713833#quit()
    1374813834
Note: See TracChangeset for help on using the changeset viewer.