【问题标题】:Getting data from odo.resource(source) to odo.resource(target)从 odo.resource(source) 获取数据到 odo.resource(target)
【发布时间】:2017-07-02 16:10:52
【问题描述】:

我正在尝试扩展 odo 库,使其具有将 GDAL 数据集(具有空间信息的栅格)转换为 NetCDF 文件的功能。

在 gdal 数据集中读取正常。但是在 netcdf 的创建阶段,我需要一些 gdal 数据集的元数据(调用 odo.odo(source,target) 时还不知道的元数据)。我怎样才能做到这一点?

到目前为止我的代码的简短版本:

import odo
from odo import resource, append
import gdal
import netCDF4 as nc4
import numpy as np

@resource.register('.+\.tif')
def resource_gdal(uri, **kwargs):
    ds = gdal.Open(uri)

    # metadata I need to transfer to netcdf
    b = ds.GetGeoTransform() #bbox, interval

   return ds


@resource.register('.+\.nc')
def resource_netcdf(uri, dshape=None, **kwargs):
    ds = nc4.Dataset(uri,'w')

    # create lat lon dimensions and variables
    ds.createDimension(lat, dshape[0].val)
    ds.createDimension(lon, dshape[1].val)
    lat = ds.createVariable('lat','f4', ('lat',))
    lon = ds.createVariable('lon','f4', ('lon',))

    # create a range from the **gdal metadata**
    lat_array = np.arange(dshape[0].val)*b[1]+b[0]
    lon_array = np.arange(dshape[1].val)*b[5]+b[3]

    # assign the range to the netcdf variable
    lat[:] = lat_array
    lon[:] = lon_array

    # create the variable which will hold the gdal data
    data = ds.createVariable('data', 'f4', ('lat', 'lon',))

   return data


@append.register(nc4.Variable, gdal.Dataset)
def append_gdal_to_nc4(tgt, src, **kwargs):
    arr = src.ReadAsArray()
    tgt[:] = arr

    return tgt

谢谢!

【问题讨论】:

    标签: gdal netcdf odo


    【解决方案1】:

    我对@9​​87654321@ 没有太多经验,但从浏览源代码和文档来看,resource_netcdf() 似乎不应该参与将 gdal 数据转换为 netcdf。翻译应该是由convert.register 修饰的gdal_to_netcdf() 函数的工作。在这种情况下,resource_gdal 返回的gdal.Dataset 对象将包含所有足够的信息(地理参考、像素大小)来制作 netcdf。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2019-06-03
      • 1970-01-01
      • 1970-01-01
      • 2014-09-20
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多