geotif 添加坐标_python – 如何获取geotif中单元格的坐标?

使用仿射变换矩阵,将像素坐标映射到世界坐标.例如,使用

affine包. (还有其他方法可以使用简单的数学方法.)

from affine import Affine

fname = '/path/to/raster.tif'

以下是获得仿射变换矩阵T0的两种方法.例如,使用GDAL / Python:

from osgeo import gdal

ds = gdal.Open(path, gdal.GA_ReadOnly)

T0 = Affine.from_gdal(*ds.GetGeoTransform())

ds = None # close

import rasterio

with rasterio.open(fname, 'r') as r:

T0 = r.affine

GDAL(T0)使用的变换数组的约定是引用像素角.您可能希望改为引用像素中心,因此需要将其翻译50%:

T1 = T0 * Affine.translation(0.5, 0.5)

现在要从像素坐标转换为世界坐标,将坐标与矩阵相乘,这可以通过一个简单的函数来完成:

rc2xy = lambda r, c: (c, r) * T1

现在,获取第一行,第二列(index [0,1])中栅格的坐标:

print(rc2xy(0, 1))

另外,请注意,如果需要从世界坐标获取像素坐标,可以使用反转仿射变换矩阵~T0.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值