IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> [python]根据两点经纬度求距离 -> 正文阅读

[Python知识库][python]根据两点经纬度求距离

数据的精度处理

from decimal import *
getcontext().prec = 9 # 默认精度为9

自定义函数

法一:用三角函数+角度

from math import radians, cos, sin, asin, sqrt
## lng表示经度;lat表示纬度
def geodistance(lng1,lat1,lng2,lat2):
    # 118.793547 32.054243
    # 118.793547 32.054243
    lng1 = Decimal(lng1)
    lat1 = Decimal(lat1)
    lng2 = Decimal(lng2)
    lat2 = Decimal(lat2)
    lng1, lat1, lng2, lat2 = map(radians, [lng1, lat1, lng2, lat2]) 
    # 经纬度转换成弧度
    dlon=lng2-lng1
    dlat=lat2-lat1
    a=sin(dlat/2)**2 + cos(lat1) * cos(lat2) * sin(dlon/2)**2
    distance=2*asin(sqrt(a))*6371*1000 # 地球平均半径,6371km~6371004米
    #distance=round(distance/1000,3) # 转化为千米
    return distance

法2:公式不同

import math
def get_lng_lat(nj,nw,oj,ow):
    nj = Decimal(nj)
    nw = Decimal(nw)
    ow = Decimal(oj)
    oj = Decimal(ow)
    C = math.cos(nw) * math.cos(ow) * math.cos(nj - oj) + math.sin(nw) * math.sin(ow)
    R = 6371004  # 半径为米
    Dis = int(R * math.acos(C))
    return Dis

这两种方法不知道哪种正确。但是根据导包的运算结果来说,第一种更准确点。
d i s t a n c e = a c o s ( s i n ( l a t a ) ? s i n ( l a t b ) + c o s ( l a t a ) ? c o s ( l a t b ) ? c o s ( l o n a ? l o n b ) ) ? R ; distance = acos( sin(lat_a) * sin(lat_b) + cos(lat_a) * cos(lat_b) * cos(lon_a - lon_b) ) * R; distance=acos(sin(lata?)?sin(latb?)+cos(lata?)?cos(latb?)?cos(lona??lonb?))?R;

法3:

见联接:
https://blog.csdn.net/zhuqiuhui/article/details/53180395

导包

from geopy.distance import geodesic
dic3=geodesic((32.054243,118.793547),(32.058552,118.797639)).m
# .m代表单位米;.km代表千米
print(dic3)

求1米对应的经纬度

地球半径:6378137米
任意地球经度周长:2 * 6378137米 * Math.PI = 40075016.68557849 米
南纬38度地球周长: 40075016.68557849 * Math.cos(32) = 33431515.091797758米
方法:360度/周长~~1米的度数
前提:为了简化计算,我们采用球形映射,而不是椭球体形状

a = 40075016.68557849 * math.cos(32) 
print(a)
w = 100 *360/a 
print(w)
  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2022-01-30 18:53:50  更:2022-01-30 18:54:37 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/4 12:40:25-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码