當前位置: 首頁>>代碼示例>>Python>>正文


Python Cdo.stdatm方法代碼示例

本文整理匯總了Python中cdo.Cdo.stdatm方法的典型用法代碼示例。如果您正苦於以下問題:Python Cdo.stdatm方法的具體用法?Python Cdo.stdatm怎麽用?Python Cdo.stdatm使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在cdo.Cdo的用法示例。


在下文中一共展示了Cdo.stdatm方法的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_cdf

# 需要導入模塊: from cdo import Cdo [as 別名]
# 或者: from cdo.Cdo import stdatm [as 別名]
 def test_cdf(self):
     cdo = Cdo()
     self.assertTrue(hasattr(cdo, "cdf"))# not in cdo.__dict__)
     if cdo.hasNetcdf:
       sum = cdo.fldsum(input = cdo.stdatm("0",options="-f nc"),returnCdf=True)
       self.assertEqual(1013.25,sum.variables["P"][:])
     else:
       self.assertRaises(ImportError,cdo.fldsum,input = cdo.stdatm("0",options="-f nc"),returnCdf=True)
開發者ID:Try2Code,項目名稱:cdo-bindings,代碼行數:10,代碼來源:test_cdo.py

示例2: test_simple

# 需要導入模塊: from cdo import Cdo [as 別名]
# 或者: from cdo.Cdo import stdatm [as 別名]
 def test_simple(self):
     cdo = Cdo()
     cdo.debug = DEBUG
     s   = cdo.sinfov(input="-topo",options="-f nc")
     s   = cdo.sinfov(input="-remapnn,r36x18 -topo",options="-f nc")
     f   = tempfile.NamedTemporaryFile(delete=True,prefix='cdoPy').name
     cdo.expr("'z=log(abs(topo)+1)*9.81'",input="-topo", output=f, options="-f nc")
     s   = cdo.infov(input=f)
     cdo.stdatm("0",output=f,options="-f nc")
     rm([f,])
開發者ID:Try2Code,項目名稱:cdo-bindings,代碼行數:12,代碼來源:test_cdo.py

示例3: test_cdiMeta

# 需要導入模塊: from cdo import Cdo [as 別名]
# 或者: from cdo.Cdo import stdatm [as 別名]
 def test_cdiMeta(self):
   cdo = Cdo()
   if cdo.hasNetcdf:
     ofile = cdo.stdatm("0", returnCdf = True)
     if DEBUG:
       print(ofile)
   if cdo.hasXarray:
     ofile = cdo.stdatm("0", returnXArray = 'T')
     if DEBUG:
       print(ofile)
       print(ofile.attrs)
     ofile = cdo.stdatm("0", returnXDataset=True)
     if DEBUG:
       print(ofile)
       print(ofile.attrs)
開發者ID:Try2Code,項目名稱:cdo-bindings,代碼行數:17,代碼來源:test_cdo.py

示例4: test_verticalLevels

# 需要導入模塊: from cdo import Cdo [as 別名]
# 或者: from cdo.Cdo import stdatm [as 別名]
 def test_verticalLevels(self):
     cdo = Cdo()
     # check, if a given input files has vertival layers of a given thickness array
     targetThicknesses = [50.0,  100.0,  200.0,  300.0,  450.0,  600.0,  800.0, 1000.0, 1000.0, 1000.0]
     sourceLevels = "25 100 250 500 875 1400 2100 3000 4000 5000".split()
     thicknesses = cdo.thicknessOfLevels(input = "-selname,T " + cdo.stdatm(','.join(sourceLevels),options = "-f nc"))
     self.assertEqual(targetThicknesses,thicknesses)
開發者ID:Try2Code,項目名稱:cdo-bindings,代碼行數:9,代碼來源:test_cdo.py

示例5: test_returnCdf

# 需要導入模塊: from cdo import Cdo [as 別名]
# 或者: from cdo.Cdo import stdatm [as 別名]
 def test_returnCdf(self):
     cdo = Cdo()
     ofile = tempfile.NamedTemporaryFile(delete=True,prefix='cdoPy').name
     press = cdo.stdatm("0",output=ofile,options="-f nc")
     self.assertEqual(ofile,press)
     if cdo.hasNetcdf:
       variables = cdo.stdatm("0",returnCdf=True).variables
       print(variables)
       cdf = cdo.stdatm("0",returnCdf=True)
       press = cdf.variables['P'][:]
       self.assertEqual(1013.25,press.min())
       press = cdo.stdatm("0",output=ofile,options="-f nc")
       self.assertEqual(ofile,press)
     else:
       self.assertRaises(ImportError,cdo.stdatm,0,returnCdf=True)
     rm([ofile,])
開發者ID:Try2Code,項目名稱:cdo-bindings,代碼行數:18,代碼來源:test_cdo.py

示例6: test_bndLevels

# 需要導入模塊: from cdo import Cdo [as 別名]
# 或者: from cdo.Cdo import stdatm [as 別名]
 def test_bndLevels(self):
     cdo = Cdo()
     ofile = cdo.stdatm(25,100,250,500,875,1400,2100,3000,4000,5000,options = "-f nc")
     self.assertEqual([0, 50.0, 150.0, 350.0, 650.0, 1100.0, 1700.0, 2500.0, 3500.0, 4500.0, 5500.0],
                 cdo.boundaryLevels(input = "-selname,T " + ofile))
     self.assertEqual([50.0, 100.0, 200.0, 300.0, 450.0, 600.0, 800.0, 1000.0, 1000.0, 1000.0],
                  cdo.thicknessOfLevels(input = ofile))
開發者ID:Try2Code,項目名稱:cdo-bindings,代碼行數:9,代碼來源:test_cdo.py

示例7: test_returnXDataset

# 需要導入模塊: from cdo import Cdo [as 別名]
# 或者: from cdo.Cdo import stdatm [as 別名]
 def test_returnXDataset(self):
     cdo = Cdo()
     if cdo.hasXarray:
       sum = cdo.fldsum(input = cdo.stdatm("0",options="-f nc"),returnXDataset=True)
       self.assertEqual(1013.25,sum.variables["P"][:])
     else:
       self.assertRaises(ImportError,
           cdo.fldsum,
           input = '-topo',returnXDataset=True)
開發者ID:Try2Code,項目名稱:cdo-bindings,代碼行數:11,代碼來源:test_cdo.py

示例8: test_errorException

# 需要導入模塊: from cdo import Cdo [as 別名]
# 或者: from cdo.Cdo import stdatm [as 別名]
    def test_errorException(self):
        cdo = Cdo()
        cdo.__print__('test_errorException')
        self.assertFalse(hasattr(cdo, 'nonExistingMethod'))
        self.assertFalse(not 'max' in cdo.operators)
        self.failUnlessRaises(CDOException, cdo.max)
        try:
            cdo.max()
        except CDOException as e:
            self.assertTrue(e.returncode != 0)
            self.assertTrue(len(e.stderr) > 1)
            self.assertTrue(hasattr(e, 'stdout'))

        try:
            cdo.stdatm(0,10,input="",output="")
        except CDOException as e:
            self.assertTrue(e.returncode != 0)
            self.assertTrue(len(e.stderr) > 1)
            self.assertTrue(hasattr(e, 'stdout'))
開發者ID:Try2Code,項目名稱:cdo-bindings,代碼行數:21,代碼來源:test_cdo.py

示例9: test_returnArray

# 需要導入模塊: from cdo import Cdo [as 別名]
# 或者: from cdo.Cdo import stdatm [as 別名]
    def test_returnArray(self):
        cdo = Cdo()
        cdo.debug = DEBUG
        if cdo.hasNetcdf:
          self.assertRaises(LookupError, cdo.stdatm,0, returnArray = 'TT')
          temperature = cdo.stdatm(0,returnArray = 'T')
          self.assertEqual(288.0,temperature.flatten()[0])
#TODO       pressure = cdo.stdatm("0,1000",options = '-f nc -b F64',returnArray = 'P')
#TODO       self.assertEqual("[ 1013.25         898.54345604]",pressure.flatten().__str__())
        else:
          self.assertRaises(ImportError, cdo.stdatm,0, returnArray = 'TT')
          self.assertRaises(ImportError, cdo.stdatm,0, returnArray = 'T')
開發者ID:Try2Code,項目名稱:cdo-bindings,代碼行數:14,代碼來源:test_cdo.py

示例10: test_inputArray

# 需要導入模塊: from cdo import Cdo [as 別名]
# 或者: from cdo.Cdo import stdatm [as 別名]
 def test_inputArray(self):
     cdo = Cdo()
     cdo.debug = DEBUG
     # check for file input
     fileA = cdo.stdatm(0,output='A_{0}'.format( random.randrange(1,100000)))
     fileB = cdo.stdatm(0,output='B_{0}'.format( random.randrange(1,100000)))
     files = [fileA,fileB]
     self.assertEqual(cdo.diffv(input = ' '.join(files)), cdo.diffv(input = files))
     self.assertEqual([],cdo.diffv(input = files))
     # check for operator input
     self.assertEqual([],cdo.diffv(input = ["-stdatm,0","-stdatm,0"]))
     # check for operator input and files
     self.assertEqual([],cdo.diffv(input = ["-stdatm,0",fileB]))
     rm([fileA, fileB])
開發者ID:Try2Code,項目名稱:cdo-bindings,代碼行數:16,代碼來源:test_cdo.py

示例11: test_forceOutput

# 需要導入模塊: from cdo import Cdo [as 別名]
# 或者: from cdo.Cdo import stdatm [as 別名]
    def test_forceOutput(self):
        cdo = Cdo()
        cdo.debug = DEBUG
        outs = []
        # tempfiles
        outs.append(cdo.stdatm("0,10,20"))
        outs.append(cdo.stdatm("0,10,20"))
        self.assertNotEqual(outs[0],outs[1])
        outs = []

        # deticated output, force = true (=defaut setting)
        ofile = 'test_force_{0}'.format( random.randrange(1,100000))
        outs.append(cdo.stdatm("0,10,20",output = ofile))
        mtime0 = os.stat(ofile).st_mtime
        #to make it compatible with systems providing no nanos.
        time.sleep(1)
        outs.append(cdo.stdatm("0,10,20",output = ofile))
        mtime1 = os.stat(ofile).st_mtime
        self.assertNotEqual(mtime0,mtime1)
        self.assertEqual(outs[0],outs[1])
        os.remove(ofile)
        outs = []

        # dedicated output, force = false
        ofile = 'test_force_false_{0}'.format( random.randrange(1,100000))
        outs.append(cdo.stdatm("0,10,20",output = ofile,force=False))
        mtime0 = os.stat(outs[0]).st_mtime
        outs.append(cdo.stdatm("0,10,20",output = ofile,force=False))
        mtime1 = os.stat(outs[1]).st_mtime
        self.assertEqual(mtime0,mtime1)
        self.assertEqual(outs[0],outs[1])
        os.remove(ofile)
        outs = []

        # dedicated output, global force setting
        ofile = 'test_force_global_{0}'.format( random.randrange(1,100000))
        cdo.forceOutput = False
        outs.append(cdo.stdatm("0,10,20",output = ofile))
        mtime0 = os.stat(outs[0]).st_mtime
        outs.append(cdo.stdatm("0,10,20",output = ofile))
        mtime1 = os.stat(outs[1]).st_mtime
        self.assertEqual(mtime0,mtime1)
        self.assertEqual(outs[0],outs[1])
        os.remove(ofile)
        outs = []
開發者ID:Try2Code,項目名稱:cdo-bindings,代碼行數:47,代碼來源:test_cdo.py

示例12: test_env

# 需要導入模塊: from cdo import Cdo [as 別名]
# 或者: from cdo.Cdo import stdatm [as 別名]
    def test_env(self):
        # clean up
        tag = 'test___env_test_{0}'.format( random.randrange(1,100000))
        files = glob.glob(tag+'*')
        rm(files)
        files = glob.glob(tag+'*')
        self.assertEqual([],files)

        # setup
        cdo = Cdo()
        cdo.debug = DEBUG
        self.assertEqual(os.environ,cdo.env)

        cdo.__print__('test_env')
        # cdf default
        ifile = cdo.stdatm(10,20,50,100,options='-f nc')
        cdo.splitname(input=ifile,output=tag)
        files = glob.glob(tag+'*')
        files.sort()
        self.assertEqual(['%sP.nc'%(tag), '%sT.nc'%(tag)],files)
        rm(files)

        # manual setup to nc2 via operator call
        cdo.splitname(input=ifile,output=tag,env={"CDO_FILE_SUFFIX": ".foo"})
        cdo.env = {}
        files = glob.glob(tag+'*')
        files.sort()
        self.assertEqual(['%sP.foo'%(tag), '%sT.foo'%(tag)],files)
        rm(files)

        # manual setup to nc2 via object setup
        cdo.__print__('test_env:VOR BLA')
        cdo.env = {"CDO_FILE_SUFFIX": ".bla"}
        cdo.splitname(input=ifile,output=tag)
        cdo.splitname(input=ifile,output='bla')
        cdo.__print__('test_env:NACH BLA')
        cdo.env = {}
        files = glob.glob(tag+'*')
        files.sort()
        self.assertEqual(['%sP.bla'%(tag), '%sT.bla'%(tag)],files)
        rm(files)
        cdo.__print__('test_env:ENDE')
開發者ID:Try2Code,項目名稱:cdo-bindings,代碼行數:44,代碼來源:test_cdo.py

示例13: test_showlevels

# 需要導入模塊: from cdo import Cdo [as 別名]
# 或者: from cdo.Cdo import stdatm [as 別名]
 def test_showlevels(self):
     cdo = Cdo()
     sourceLevels = "25 100 250 500 875 1400 2100 3000 4000 5000".split()
     self.assertEqual(' '.join(sourceLevels),
                     cdo.showlevel(input = "-selname,T " + cdo.stdatm(','.join(sourceLevels),options = "-f nc"))[0])
開發者ID:Try2Code,項目名稱:cdo-bindings,代碼行數:7,代碼來源:test_cdo.py

示例14: test_combine

# 需要導入模塊: from cdo import Cdo [as 別名]
# 或者: from cdo.Cdo import stdatm [as 別名]
 def test_combine(self):
     cdo = Cdo()
     cdo.debug = DEBUG
     stdatm  = cdo.stdatm("0",options = "-f nc")
     stdatm_ = cdo.stdatm("0",options = "-f nc")
開發者ID:Try2Code,項目名稱:cdo-bindings,代碼行數:7,代碼來源:test_cdo.py


注:本文中的cdo.Cdo.stdatm方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。