Python 利用rasterio库进行坐标转换

这是一篇必应上找的手册上的文章,特此记录
参考链接:
原文
参考链接2
影像中的RPC信息

1、仿射变换矩阵转换

在这里插入图片描述
上面说的利用仿射转换矩阵进行转换,一些注意事项可以参考原文,复现代码

import rasterio
from rasterio import transform,Affine

def Demo1_Affine():
    trans = Affine(300.0379266750948, 0.0, 101985.0, 0.0,-300.041782729805, 2826915.0)#这个测数据不是很懂,为啥通过这些数据就能简历下面的仿射关系
    transformer = rasterio.transform.AffineTransformer(trans)
    GeoPoint = transformer.xy(0, 0)
    PixPoint = transformer.rowcol(102135.01896333754, 2826764.979108635)
    print("GeoPoint:",GeoPoint)
    print("PixPoint:",PixPoint)

Demo1_Affine()

2、使用控制点转换

import rasterio
from rasterio import transform,Affine
from rasterio.control import GroundControlPoint

def Demo2_GCP():
    gcps = [GroundControlPoint(row=11521.5, col=0.5, x=-123.6185142817931, y=48.99561141948625, z=89.13533782958984,
                               id='217', info=''),
            GroundControlPoint(row=11521.5, col=7448.5, x=-122.8802747777599, y=48.91210259315549, z=89.13533782958984,
                               id='234', info=''),
            GroundControlPoint(row=0.5, col=0.5, x=-123.4809665720148, y=49.52809729106944, z=89.13533782958984, id='1',
                               info=''),
            GroundControlPoint(row=0.5, col=7448.5, x=-122.7345733674704, y=49.44455878004666, z=89.13533782958984,
                               id='18', info='')]
    transformer = rasterio.transform.GCPTransformer(gcps)
    test= transformer.xy(0, 0)#输入像素位置,输出经纬度位置
    test2= transformer.rowcol(-123.478928146887, 49.52808986989645)#输入经纬度位置,输出像素位置
    print("test:",test)
    print("test2:",test2)

Demo2_GCP()

在这里插入图片描述

3、使用RPC进行坐标点转换

在这里插入图片描述
在这里插入图片描述

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Python 中,可以使用 pyproj 进行坐标转换。使用 pyproj 需要先安装它,可以使用以下命令进行安装: ``` pip install pyproj ``` 安装完成后,就可以在 Python 程序中使用 pyproj 了。下面是一个使用 pyproj 进行坐标转换的示例代码: ```python import pyproj # 定义投影坐标系 p1 = pyproj.Proj(init='epsg:4326') # WGS84 坐标系 p2 = pyproj.Proj(init='epsg:3857') # Web Mercator 坐标系 # 定义待转换的坐标 x, y = 120.123, 30.456 # 进行坐标转换 x2, y2 = pyproj.transform(p1, p2, x, y) print(x2, y2) # 输出转换后的坐标 ``` 在这个示例中,我们将 WGS84 坐标系下的坐标 (120.123, 30.456) 转换为 Web Mercator 坐标系下的坐标。p1 和 p2 分别表示原坐标系和目标坐标系。使用 pyproj.transform() 函数可以进行坐标转换,它需要传入原坐标系、目标坐标系和待转换的坐标。最后,转换后的坐标会被输出。 注意,在进行坐标转换时,需要确保原坐标系和目标坐标系是可以相互转换的。通常情况下,两个坐标系是可以相互转换的, ### 回答2: Python 中使用 `proj` 参数是为了进行坐标转换。`proj` 是一个经纬度坐标转换,可以将不同坐标系之间的位置进行转换。 在 Python 中,可以使用 `pyproj` 进行坐标转换。`pyproj` 是一个非常常用的,它提供了各种坐标转换的方法和函数。 首先,需要安装 `pyproj` 。可以使用 `pip install pyproj` 命令进行安装。 安装完成后,可以使用以下代码进行坐标转换: ```python from pyproj import Proj # 定义源坐标系 source_proj = Proj(init='epsg:4326') # 定义目标坐标系 target_proj = Proj(init='epsg:3857') # 定义源坐标 lon, lat = 120.123, 30.456 # 进行坐标转换 x, y = pyproj.transform(source_proj, target_proj, lon, lat) # 输出转换后的坐标 print(f'转换后的坐标为:{x}, {y}') ``` 在上面的代码中,首先定义了源坐标系和目标坐标系,`epsg:4326` 表示 WGS84 坐标系,`epsg:3857` 表示 Web Mercator 坐标系。然后定义了源坐标的经度和纬度,使用 `pyproj.transform` 函数进行转换。最后输出转换后的坐标。 这样,就可以利用 `proj` 参数进行坐标转换。使用 `pyproj` 提供的方法,可以方便地进行不同坐标系之间的转换。 ### 回答3: 在Python中,可以使用proj参数进行坐标转换。proj参数是一个字符串,用于定义坐标系统的投影方式和坐标单位。 proj参数可以通过多种方式指定。一种常见的方式是使用EPSG代码,这是一种国际标准的坐标系统编号。例如,EPSG:4326表示WGS 84坐标系统,EPSG:3857表示Web墨卡托投影坐标系统。在Python中,可以通过proj参数将一种坐标系统的坐标转换为另一种坐标系统的坐标。 要使用proj参数进行坐标转换,首先需要安装PyProj。PyProj是一个用于地理坐标转换Python,可以通过pip安装。安装完成后,可以使用pyproj.Proj函数创建一个Proj对象,将proj参数传递给该函数。 创建Proj对象后,可以使用该对象的transform方法进行坐标转换。transform方法接受两个参数,分别是源坐标系和目标坐标系的Proj对象。例如,要将WGS 84坐标转换为Web墨卡托投影坐标,可以创建两个Proj对象,分别代表这两个坐标系,然后使用transform方法进行转换。 下面是一个示例代码,演示了如何使用proj参数进行坐标转换: ```python import pyproj # 创建两个Proj对象,分别代表WGS 84坐标系和Web墨卡托投影坐标系 wgs84 = pyproj.Proj(proj='latlong', datum='WGS84', ellps='WGS84') webmercator = pyproj.Proj(proj='merc', datum='WGS84', ellps='WGS84', lat_ts=0.0, lon_0=0.0, x_0=0.0, y_0=0, units='m', k=1.0, nadgrids='@null', no_defs=True) # 坐标转换 lon, lat = 116.4074, 39.9042 # WGS 84坐标 x, y = pyproj.transform(wgs84, webmercator, lon, lat) # 转换为Web墨卡托投影坐标 print(x, y) ``` 以上就是使用proj参数进行坐标转换的方法。通过使用Proj对象和transform方法,可以方便地实现不同坐标系统之间的坐标转换
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值