当前位置: 移动技术网 > IT编程>脚本编程>Python > Python经纬度坐标转换为距离及角度的实现

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

2020年11月01日  | 移动技术网IT编程  | 我要评论
最近项目上有这样的需求,需要依据设备的经纬度坐标计算距离及角度。经验证后效果较好,并分享。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)为终点,结合百度地图、谷歌地图等进行效果验证。

程序运行结果如下:

百度测距为38.3km

google地图手动测距为39.31km

 

距离与角度均无问题。 

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

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网