【PythonGIS】矢量数据投影转换(坐标转换)

news2024/11/28 22:42:12

        之前跟大家分享过面矢量数据投影转换和点矢量数据投影转换,但博主在日常工作的过程中发现之前分享的面矢量数据投影转换有时候会出现错误,或者转换后的效果不好。再一次偶然的过程中发现了新的坐标转换(投影转换)函数,所以今天和大家分享一下,大家在进行坐标转换时可以两种方法都试试,哪个效果好用哪个。

一、导入库

from osgeo import gdal, ogr, osr

二、坐标转换函数

        这里最重要的就是gdal.VectorTranslate这个函数,这个函数包含了很多参数,代码中已给出相关注释,大家如果还有什么问题,可以直接去查看下官方文档。

        此外我这里的目标坐标系是使用EPSG编码定义的,之前分享的文章中展示过从已有文件中提取坐标系,大家可以去看下然后放入代码即可。这里给大家分享两个查询EPSG编码的网站。

mygeodata.cloudicon-default.png?t=N7T8https://mygeodata.cloud/cs2cs/

epsg.oiicon-default.png?t=N7T8https://epsg.io/

def Projection_Transform(shape_path, save_path, epsg):
    ogr.RegisterAll()
    # 注册所有驱动
    gdal.SetConfigOption("SHAPE_ENCODING", "UTF-8")
    # 定义编码类型为UTF8,防止字段乱码
    ds = ogr.Open(shape_path)
    layer = ds.GetLayer()
    # 打开需要转换的矢量数据,获取图层
    src_proj = layer.GetSpatialRef()
    # 获取其源坐标信息
    layer_name = layer.GetName()
    # 获取图层名称
    ds.Destroy()
    dst_proj = osr.SpatialReference()
    dst_proj.ImportFromEPSG(epsg)
    # 定义目标投影的空间信息
    options = gdal.VectorTranslateOptions(
        format="ESRI Shapefile",
        # 输出格式
        accessMode=None,
        srcSRS=src_proj,
        # 源坐标系
        dstSRS=dst_proj,
        # 目标坐标系
        reproject=True,
        selectFields=None,
        # 保留全部字段
        layerName=layer_name,
        # 图层名称
        geometryType="POLYGON",
        # 数据类型
        dim="XY"
    )
    gdal.VectorTranslate(save_path, srcDS=shape_path, options=options)

三、完整代码

# -*- coding: utf-8 -*-
"""
@Time : 2023/8/22 17:59
@Auth : RS迷途小书童
@File :Vector Data Projection Transform.py
@IDE :PyCharm
@Purpose :矢量数据投影转换/坐标转换
"""
from osgeo import gdal, ogr, osr


def Projection_Transform(shape_path, save_path, epsg):
    ogr.RegisterAll()
    # 注册所有驱动
    gdal.SetConfigOption("SHAPE_ENCODING", "UTF-8")
    # 定义编码类型为UTF8,防止字段乱码
    ds = ogr.Open(shape_path)
    layer = ds.GetLayer()
    # 打开需要转换的矢量数据,获取图层
    src_proj = layer.GetSpatialRef()
    # 获取其源坐标信息
    layer_name = layer.GetName()
    # 获取图层名称
    ds.Destroy()
    dst_proj = osr.SpatialReference()
    dst_proj.ImportFromEPSG(epsg)
    # 定义目标投影的空间信息
    options = gdal.VectorTranslateOptions(
        format="ESRI Shapefile",
        # 输出格式
        accessMode=None,
        srcSRS=src_proj,
        # 源坐标系
        dstSRS=dst_proj,
        # 目标坐标系
        reproject=True,
        selectFields=None,
        # 保留全部字段
        layerName=layer_name,
        # 图层名称
        geometryType="POLYGON",
        # 数据类型
        dim="XY"
    )
    gdal.VectorTranslate(save_path, srcDS=shape_path, options=options)


if __name__ == "__main__":
    in_path = "B:/Personal/九段西.shp"
    out_path = "B:/Personal/九段西1.shp"
    in_path.replace("/", "\\")
    Projection_Transform(in_path, out_path, epsg=4550)
    # 输入文件,输出文件,目标坐标系

        今天给大家分享了矢量数据投影转换、坐标转换的新方法,大家可以结合一下之前发的博客,挑选适合自己的方法。

        如果大家在学习Python或者RS时有什么问题,可以随时留言交流!如果大家对批量处理有兴趣同样可以留言给博主,博主会分享相关代码以供学习!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/992198.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【linux】进程优先级,进程切换

进程 1.进程优先级(了解)2.进程切换 1.进程优先级(了解) 1.什么叫做进程优先级? 我们知道权限是能还是不能做的问题,那对应的优先级就是能做,但是是先做还是后做的问题。 2.为什么存在优先级…

vite项目启动use `--host` to expose

Vite 启动项目后,发现只有localhost 端口 服务,没有 IP 端口服务。 运行npm run serve,终端提示Vite启动后提示Network: use ‘–host’ to expose。 在vite.config.js中配置server import {defineConfig } from vite import vue from vi…

MySQL学习5:事务、存储引擎

事务 简介 事务是一组数据库操作的执行单元,它要么完全执行,要么完全不执行。事务是确保数据库中的数据一致性和完整性的重要机制之一。 事务具有以下四个特性(称为ACID特性): 原子性(Atomicity&#xf…

Discourse 能支持多少数量的主题

支持主题的数量和 ID 使用的数据类型有关。 根据我们从 Discourse 上 dump 出来的 SQL,我们看到 Discourse 的官方使用 Integer 作为 ID 的数据类型。 随后,我们查看了 pgsql 的官方文档,integer 是 4 字节的,能够存储的最大值为…

智能合约安全分析,假充值攻击如何突破交易所的防御?

智能合约安全分析,假充值攻击如何突破交易所的防御? 引言 假充值攻击,是指攻击者通过利用交易所在处理充值过程中的漏洞或系统错误,发送伪造的交易信息到交易所钱包地址,这些伪造的交易信息被交易所误认为是真实的充值…

系统架构设计师(第二版)学习笔记----计算机网络

【原文链接】系统架构设计师(第二版)学习笔记----计算机网络 文章目录 一、计算机网络的基本概念1.1 计算机网络的发展阶段1.2 计算机网络的功能1.3 计算机网络的性能指标1.4 计算机网络的非性能指标 二、通信技术2.1 发信机的信号处理流程2.2 收信机的信…

运维经验记录 在CentOS上挂载Windows共享磁盘

1、需求: 非root用户(普通用户)能够读写windows共享目录,比如查看文件、创建文件、修改文件、删除文件 # 让普通用户也可以正常读写 uidvalue and gidvalue Set the owner and group of the root of the file system (default: …

再谈内存分配器的优缺点

结论 在频繁申请、释放内存的工作场景,建议需要考虑定制化的内存分配器Allocator 优点 那么用内存分配器有那些好处呢?在近段研究和积累看来,主要有以下几点: 拥有连续内存的访问优势较浅的申请、释放栈访问深度;甚…

攻防世界-WEB-upload1

打开靶机上传文件 必须上传图片,F12审计一下代码 发现校验代码 一句话木马,使用菜刀连接 通过bp修改文件类型 get成功,证明文件已经上传 修改POST请求 得到上传成功的文件,请求文件名 得到flag cyberpeace{5a97279c34e62…

The timestamp difference between admin and executor exceeds the limit.解决办法

前言: 使用xxjob报错了,图文如下: 2023-09-09 10:28:54 [com.xxl.job.core.thread.JobThread#run]-[127]-[Thread-191] ----------- xxl-job job execute start ----------- ----------- Param: 2023-09-09 10:28:54 [com.xxl.job.core.thre…

企业架构LNMP学习笔记27

Keepalived的配置补充: 脑裂(裂脑):vip出现在了多台机器上。网络不通畅,禁用了数据包,主备服务器没法通讯,造成备服务器认为主服务器不可用,绑定VIP,主服务器VIP不会释放…

安卓如何设置开机启动某个程序?init.rc给你搞定

一、如何设置开机启动某个程序? 1.需求描述 最近有个项目需要在Android开机启动之后,自动执行一个C语言编写的程序:pengd 该程序运行时需要修改网络ip地址及其他网络操作,所以需要root权限 根据需求描述,我们需要做…

算法-88.合并两个有序数组-简单

给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2,另有两个整数 m 和 n ,分别表示 nums1 和 nums2 中的元素数目。 请你 合并 nums2 到 nums1 中,使合并后的数组同样按 非递减顺序 排列。 注意:最终,合并后数组…

【Idea】IntelliJ IDEA 2023版本,.java文件报 no scalac found to compile scala sources问题

maven install没问题,新版本idea中编译则报错。 原因应该是新旧版本对Scala Compiler的调用逻辑有差异。造成的,因为同样的工程,在旧版本里可以正常编译。 解决方法 Settings > Build, Execution, Deployment > Compiler > Scala…

【区块链】DeFi是什么?大白话科普文

对于一些没有玩过区块链、或者说没有真金白银的体验过这个虚拟世界的小伙伴来说,这篇文章可以帮你了解 DeFi。致力于帮你在这个线上走出这一步。 当然这不是理财建议。 文章目录 前言什么是去中心化金融?有哪些 DeFi 项目DeFi由哪几部分构成?热门DeFi项目有哪些?前言 Def…

【C++】封装map和set(红黑树实现)

前言: 前面,我们学习了set和map的用法,这两个容器可以完成查找,排序等操作,后来我们在学习过二叉搜索树的基础上又学习了两种特殊的二叉搜索树——AVL树和红黑树,他们俩可以是效率进一步提高,其…

stm32f103rct6系统结构框图

一、其中,APB1总线和APB2总线的区别有: 1、时钟频率: APB1是低速总线(一般为36M),这意味着APB1总线上的外设运行在较低的时钟速度下,适合处理一些低速外设,如USART、I2C等。 APB2…

工作新时代,腾讯轻联塑造高效办公未来

腾讯轻联:开启便捷、高效的集成新纪元 ⭐ 写在前面⭐ 使用模板快速起步⭐ 自定义流程初体验⭐ 无与伦比的集成强者⭐ 写在最后 ⭐ 写在前面 在当今竞争激烈的商业环境中,提高企业的办公效率和工作流程自动化变得至关重要。腾讯轻联,作为新一…

对于pytorch和对应pytorch网站的探索

一、关于网站上面的那个教程: 适合PyTorch小白的官网教程:Learning PyTorch With Examples - 知乎 (zhihu.com) 这个链接也是一样的, 总的来说,里面讲了这么一件事: 如果没有pytorch的分装好的nn.module用来继承的话,需要设计…

营销邮件主题怎么写?编写邮件主题的技巧?

如何创建营销邮件主题?制作EDM邮件主题的方法策略? 营销邮件主题在整个营销邮件中起着至关重要的作用,它是吸引读者打开邮件的第一步。蜂邮EDM将分享一些关于如何撰写令人惊艳的营销邮件主题的技巧,帮助您吸引更多的目标受众。 …