我有一个opendap三个链接到一个目录,其中保存着来自特拉华州业务预测系统(DBOFS)的许多海洋学模型输出文件。历史数据存储在单独的每小时文件中,甚至有些文件跨越多个小时。我想把这些文件当作一个很长的时间序列来看。我在这里遇到了另一个类似的问题:Loop through netcdf files and run calculations - Python or R
使用通配符进行搜索返回以下错误:
import netCDF4
f = netCDF4.MFDataset('http://opendap.co-ops.nos.noaa.gov/thredds/dodsC/NOAA/DBOFS/MODELS/201401/nos.dbofs.fields.n001.20140130.*.nc')
---------------------------------------------------------------------------
ValueError Traceback (most recent call last)
<ipython-input-3-a44e21cddbe9> in <module>()
----> 1 f = netCDF4.MFDataset('http://opendap.co-ops.nos.noaa.gov/thredds/dodsC/NOAA/DBOFS/MODELS/201401/nos.dbofs.fields.n001.20140130.*.nc')
C:\Users\cenglert\AppData\Local\Enthought\Canopy32\User\lib\site-packages\netCDF4.pyd in netCDF4.MFDataset.__init__ (netCDF4.c:6458)()
ValueError: cannot using file globbing for remote (OPeNDAP) datasets发布于 2014-04-16 18:38:46
正如错误说明的那样,您不能在远程数据集中使用globbing (使用*作为通配符),但是您可以构建dataset URL的python列表并将它们传递给MFDataset。如下所示:
import netCDF4
base = 'http://opendap.co-ops.nos.noaa.gov/thredds/dodsC/\
NOAA/DBOFS/MODELS/201401/nos.dbofs.fields.n001.20140130.t%2.2dz.nc'
files = [base % d for d in range(0,24,6)]
nc = netCDF4.MFDataset(files)
print nc.variables['salt']它产生:
<class 'netCDF4._Variable'>
float64 salt('ocean_time', 's_rho', 'eta_rho', 'xi_rho')
long_name: salinity
time: ocean_time
coordinates: lat_rho lon_rho
field: salinity, scalar, series
unlimited dimensions = ('ocean_time',)
current size = (4, 10, 732, 119)并且表明,实际上,在0,6,12和18小时的四个值实际上已经被MFDataset聚合。
https://stackoverflow.com/questions/23116570
复制相似问题