欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Python经纬度坐标转换为距离及角度的实现

程序员文章站 2022-07-02 11:23:45
最近项目上有这样的需求,需要依据设备的经纬度坐标计算距离及角度。经验证后效果较好,并分享。1 经纬度转换距离代码#!/usr/bin/env python# -*- coding: utf-8 -*-...

最近项目上有这样的需求,需要依据设备的经纬度坐标计算距离及角度。经验证后效果较好,并分享。

1 经纬度转换距离代码

#!/usr/bin/env python
# -*- coding: utf-8 -*-
__author__ = 'seven'


import math


# 计算距离
def getdistance(lata, lona, latb, lonb):
  ra = 6378140 # 赤道半径
  rb = 6356755 # 极半径
  flatten = (ra - rb) / ra # partial rate of the earth
  # change angle to radians
  radlata = math.radians(lata)
  radlona = math.radians(lona)
  radlatb = math.radians(latb)
  radlonb = math.radians(lonb)

  pa = math.atan(rb / ra * math.tan(radlata))
  pb = math.atan(rb / ra * math.tan(radlatb))
  x = math.acos(math.sin(pa) * math.sin(pb) + math.cos(pa) * math.cos(pb) * math.cos(radlona - radlonb))
  c1 = (math.sin(x) - x) * (math.sin(pa) + math.sin(pb)) ** 2 / math.cos(x / 2) ** 2
  c2 = (math.sin(x) + x) * (math.sin(pa) - math.sin(pb)) ** 2 / math.sin(x / 2) ** 2
  dr = flatten / 8 * (c1 - c2)
  distance = ra * (x + dr)
  distance = round(distance / 1000, 4)
  return f'{distance}km'

2 经纬度转化角度代码

#!/usr/bin/env python
# -*- coding: utf-8 -*-
__author__ = 'seven'

import math

# 计算角度
def getdegree(lata, lona, latb, lonb):
  radlata = math.radians(lata)
  radlona = math.radians(lona)
  radlatb = math.radians(latb)
  radlonb = math.radians(lonb)
  dlon = radlonb - radlona
  y = math.sin(dlon) * math.cos(radlatb)
  x = math.cos(radlata) * math.sin(radlatb) - math.sin(radlata) * math.cos(radlatb) * math.cos(dlon)
  brng = math.degrees(math.atan2(y, x))
  brng = round((brng + 360) % 360, 4)
  brng = int(brng)
  if (brng == 0.0) or ((brng == 360.0)):
    return '正北方向'
  elif brng == 90.0:
    return '正东方向'
  elif brng == 180.0:
    return '正南方向'
  elif brng == 270.0:
    return '正西方向'
  elif 0 < brng < 90:
    return f'北偏东{brng}'
  elif 90 < brng < 180:
    return f'东偏南{brng - 90}'
  elif 180 < brng < 270:
    return f'西偏南{270 - brng}'
  elif 270 < brng < 360:
    return f'北偏西{brng - 270}'
  else:
    pass

3 验证

选取深圳野生动物园(22.599578, 113.973129)为起点,深圳坪山站(22.6986848, 114.3311032)为终点,结合百度地图、谷歌地图等进行效果验证。

程序运行结果如下:

Python经纬度坐标转换为距离及角度的实现

百度测距为38.3km

google地图手动测距为39.31km

Python经纬度坐标转换为距离及角度的实现

Python经纬度坐标转换为距离及角度的实现 

距离与角度均无问题。 

到此这篇关于python经纬度坐标转换为距离及角度的实现的文章就介绍到这了,更多相关python经纬度坐标转换为距离及角度内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!