Python的经纬度与xy坐标系相互转换方式

 更新时间:2024年02月01日 09:43:42   作者:kalani呀  
这篇文章主要介绍了Python的经纬度与xy坐标系相互转换方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

经纬度与xy坐标系相互转换

代码是已经运行过的,可以直接输入参数使用

注意事项

  • 经纬度参数不可以写颠倒,否则会由于math.log参数不能为负数和0的原因报错
  • 由于地球半径的不确定性,所以(x,y)与(lon, lat)相互转换会有误差

奉上代码及运行结果

  • 经纬度转换成xy坐标

实例经维度参数 (114.5456282282352,36.631262731204049)

def millerToXY (lon, lat):
    xy_coordinate = []
    #地球周长
    L = 6381372*math.pi*2 
    #平面展开,将周长视为X轴
    W = L 
    #Y轴约等于周长一般
    H = L/2 
    #米勒投影中的一个常数,范围大约在正负2.3之间
    mill = 2.3 
    #将经度从度数转换为弧度
    x = lon*math.pi/180 
    # 将纬度从度数转换为弧度
    y = lat*math.pi/180 
    #这里是米勒投影的转换
    y = 1.25*math.log(math.tan(0.25*math.pi+0.4*y)) 
    # 这里将弧度转为实际距离 ,转换结果的单位是公里
    x = (W/2)+(W/(2*math.pi))*x
    y = (H/2)-(H/(2*mill))*y
    xy_coordinate.append((int(round(x)),int(round(y))))
    return xy_coordinate
  • xy坐标转换成经纬度
def xy_to_coor(x, y):
    lonlat_coordinate = []
    L = 6381372 * math.pi*2
    W = L
    H = L/2
    mill = 2.3
    lat = ((H/2-y)*2*mill)/(1.25*H)
    lat = ((math.atan(math.exp(lat))-0.25*math.pi)*180)/(0.4*math.pi)
    lon = (x-W/2)*360/W
    # TODO 最终需要确认经纬度保留小数点后几位
    lonlat_coordinate.append((round(lon,15),round(lat,15)))
    return lonlat_coordinate
  • 调用两个函数
import math
print(millerToXY(114.5456282282352,36.631262731204049))
print(xy_to_coor(32805300, 7107399))

打印结果

[(32805300, 7107399)]
[(114.54562994611808, 36.63126574363226)]

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 修复Python Pandas数据标记错误的几种方法总结

    修复Python Pandas数据标记错误的几种方法总结

    用于分析数据的 Python 库称为 Pandas,在 Pandas 中读取数据最常见的方式是通过 CSV 文件,但 CSV 文件的限制是它应该采用特定的格式,否则在标记数据时会抛出错误,在本文中,我们将讨论修复 Python Pandas 错误标记数据的各种方法
    2023-10-10
  • Python 基于jwt实现认证机制流程解析

    Python 基于jwt实现认证机制流程解析

    这篇文章主要介绍了python 基于jwt实现认证机制流程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-06-06
  • python字典取值的几种方法总结

    python字典取值的几种方法总结

    这篇文章主要介绍了python字典取值的几种方法总结,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • Python根据文件后缀实现文件夹整理

    Python根据文件后缀实现文件夹整理

    这篇文章主要为大家详细介绍了Python如何根据文件后缀实现文件夹整理,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的可以参考下
    2024-02-02
  • python爬虫爬取指定内容的解决方法

    python爬虫爬取指定内容的解决方法

    这篇文章主要介绍了python爬虫爬取指定内容,爬取一些网站下指定的内容,一般来说可以用xpath来直接从网页上来获取,但是当我们获取的内容不唯一的时候我们无法选择,我们所需要的、所指定的内容,需要的朋友可以参考下
    2022-06-06
  • python实现定时提取实时日志程序

    python实现定时提取实时日志程序

    这篇文章主要为大家详细介绍了python实现定时提取实时日志程序,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-06-06
  • python使用sqlite3时游标使用方法

    python使用sqlite3时游标使用方法

    这篇文章主要为大家详细介绍了python使用sqlite3时游标的使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-03-03
  • Matplotlib自定义坐标轴刻度的实现示例

    Matplotlib自定义坐标轴刻度的实现示例

    这篇文章主要介绍了Matplotlib自定义坐标轴刻度的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06
  • Python操作Word文件的流程步骤

    Python操作Word文件的流程步骤

    要操作Word文件,我们需要使用一个Python的第三方库叫做 python-docx,它可以让我们使用 Python对Word文件进行读取、修改以及创建等操作,文中有详细的流程步骤介绍,需要的朋友可以参考下
    2023-06-06
  • 图文详解梯度下降算法的原理及Python实现

    图文详解梯度下降算法的原理及Python实现

    梯度下降是迭代法的一种,可以用于求解最小二乘问题(线性和非线性都可以)。本文将通过图文详解梯度下降算法的原理及实现,需要的可以参考一下
    2022-08-08

最新评论