码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 已知点的经纬度坐标计算/读取DEM高程信息/海拔高度


    已知点的经纬度坐标计算/读取DEM高程信息/海拔高度

    • 思路
    • 环境
    • 依赖
    • 安装GDAL
    • 安装依赖包
    • 测试GDAL
    • 数据依赖
    • python代码
    • 参考

    思路

    • 实现条件
      1.GDAL库
      2.DEM数据

    • 开发语言
      python3

    • 开发环境
      Linux

    • 难度等级
      中

    环境

    • Ubuntu18.04 LTS
    • python 3.6.9

    依赖

    • GDAL
    • numpy
    • python
      szZack的博客

    安装GDAL

    • 方法1:
      inux下python3的GDAL链接如下:
      https://sourceforge.net/projects/gdal-wheels-for-linux/files/
      下载对应python版本的GDAL
      再pip安装:

      pip install GDAL-3.4.1-cp36-cp36m-manylinux_2_5_x86_64.manylinux1_x86_64.whl
      
      • 1
    • 方法2:

      # 安装的版本需要和python版本一致
      python3 -m pip install https://sourceforge.net/projects/gdal-wheels-for-linux/files/GDAL-3.4.1-cp36-cp36m-manylinux_2_5_x86_64.manylinux1_x86_64.whl/download
      
      • 1
      • 2

      szZack的博客

    • 方法3:
      【推荐方法】机器需要可以连外网

      apt-get update
      apt-get install -y python3-gdal
      
      • 1
      • 2

    安装依赖包

    • 方法1:

      pip install GDAL
      
      • 1
    • 方法2:
      先下载 GDAL-3.4.1.tar.gz
      然后解压后执行下面的指令:

      python setup.py build
      python setup.py install
      
      • 1
      • 2

    测试GDAL

    ~# python3
    Python 3.6.9 (default, Jan 26 2021, 15:33:00)
    [GCC 8.4.0] on linux
    Type "help", "copyright", "credits" or "license" for more information.
    >>> import gdal
    
    • 1
    • 2
    • 3
    • 4
    • 5

    不报错即说明安装成功!

    数据依赖

    下载高程 tif 格式数据,自行百度一下

    python代码

    from osgeo import gdal
    
    def get_elevation(tif_path, latitude, longitude):
        
        gdal.UseExceptions()
        ds = gdal.Open(tif_path)
        
        band = ds.GetRasterBand(1)
        elevation = band.ReadAsArray()
        nrows, ncols = elevation.shape
        
        x0, dx, dxdy, y0, dydx, dy = ds.GetGeoTransform()
        
        new_ncols, new_nrows = int((y0-latitude)/dx), int((longitude-x0)/dx)
        
        return elevation[new_ncols][new_nrows]
    
    
    #经纬度点坐标
    latitude, longitude = 31.15, 111.24
    h = get_elevation('./xxx.tif', latitude, longitude)
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    szZack的博客

    参考

    • https://pypi.org/project/GDAL/
    • https://www.yisu.com/zixun/689106.html
      szZack的博客
  • 相关阅读:
    低代码+流程管理,打造信息工程项目动态管理系统
    【InternLM 笔记】使用InternLM2-chat-1.8b制作时事问答知识库
    基于ZXing.NET实现的二维码生成和识别客户端
    H2N-Gly-Pro-Glu-COOH,32302-76-4
    centos7中sshd -t没内容输出日志也没内容但sshd服务重启一直失败解决方法、strace命令的使用以及使用场景说明
    第一课数组、链表、栈、队列
    左耳朵耗子:云原生的正确打开方式
    抖音短视频seo矩阵系统源代码开发系统架构及功能解析
    ETCD数据库源码分析——集群间网络层服务端RaftHandler
    Zongmu AVM车载环视 Android SDK 简介
  • 原文地址:https://blog.csdn.net/zengNLP/article/details/126262286
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号