网站首页 > 技术文章 正文
from math import radians, cos, sin, asin, sqrt,pi
class Get_new_gps():
def __init__(self):
# 地球半径
self.R = 6371 * 1000
pass
def geodistance(self, lng1, lat1, lng2, lat2):
"""计算两点间距离"""
"""
:param lng1: 120.12802999999997
:param lat1: 30.28708,115
:param lng2: 115.86572000000001
:param lat2: 28.7427
:return: 两点间距离
"""
lng1, lat1, lng2, lat2 = map(radians, [float(lng1), float(lat1), float(lng2), float(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)) * self.R # 地球平均半径,6371km
distance = round(distance, 3)
return distance
def get_new_lat(self, lng1, lat1, dist=500):
"""计算点经纬度南500米的点的经纬度"""
"""
:param lng1: 120.12803
:param lat1: 20.28708
:param dist:
:return: (120.12803, 20.291576608029594)
"""
lat2 = lat1 - 180 * dist / (self.R * pi)
return (lng1, lat2)
"""计算点经纬度正东1000米点的经纬度"""
def get_new_lng(self, lng1, lat1, dist=1000):
"""计算点经纬度正东1000米点的经纬度"""
"""
:param lng1: 116.55272514141352
:param lat1: 30.28708
:param dist:
:return: (116.55272514141352,30.28708)
"""
lng2 = 180 * dist / (self.R * pi * cos(radians(lat1))) + lng1
return (lng2, lat1)
def get_new_lng_angle(self, lng1, lat1, dist=500, angle=30):
"""计算点东北方向与正东某夹角某距离的经纬度"""
"""
:param lng1:116.55272514141352
:param lat1:30.28708
:param dist:指定距离
:param angle:指定角度
:return:(0.0091871843081617/pi + 116.498079 0.0122339171779312/pi + 39.752304)
"""
lat2 = 180 * dist*sin(radians(angle)) / (self.R * pi) + lat1
lng2 = 180 * dist*cos(radians(angle)) / (self.R * pi * cos(radians(lat1))) + lng1
return (lng2, lat2)
functions = Get_new_gps()
if __name__ == '__main__':
functions = Get_new_gps()
lng1, lat1 = [117.317732, 36.565515]
# 计算正北的点
# lng2, lat2 = functions.get_new_lat(lng1, lat1)
# 计算正东的点
lng3, lat3 = functions.get_new_lng(lng1, lat1)
# # 计算该点与正东逆时针夹角45度,距离500米点的经纬度值
# lng4, lat4 = functions.get_new_lng_angle(lng1, lat1, dist=1000, angle=45)
print("原始点的经纬度坐标", lng1, lat1)
# print("正北500米坐标点为%f,%f,距离计算为%f米" % (lng2, lat2, functions.geodistance(lng1, lat1, lng2, lat2)))
print("正东1000米坐标点为%f,%f,距离计算为%f米" % (lng3, lat3, functions.geodistance(lng1, lat1, lng3, lat3)))
# print("东北方夹角,距离500米坐标点为%f,%f,距离计算为%f米" % (float(lng3), float(lat3), functions.geodistance(lng1, lat1, lng3, lat3)))
# print(functions.geodistance(lng3, lat3, lng4, lat4))
lng, lat = [117.774649, 36.005881]
lng2, lat2 = functions.get_new_lng(lng, lat)
print("原始点的经纬度坐标", lng, lat)
print("正东1000米坐标点为%f,%f,距离计算为%f米" % (lng2, lat2, functions.geodistance(lng, lat, lng2, lat2)))
更多学习资料请关注公众号“读书同友会”
猜你喜欢
- 2025-06-24 Python DataFrame常用操作汇总(python处理dataframe数据)
- 2025-06-24 Python 小白必看!Pandas 带你秒变数据分析大神
- 2025-06-24 Python 轻松搞定 Excel 常用的 20 个操作
- 06-24Python调用Docker API的使用方式(pycharm docker 调试)
- 06-24青少年Python编程系列28:Python中函数的递归调用
- 06-24python调用sqlite数据库案例(python 调用数据库)
- 06-24【Python机器学习系列】基于Flask来构建API调用机器学习模型服务
- 06-24通过pybind11来实现python调用C++接口(一)
- 06-24Python编程调用Deepseek API创建智能体
- 06-24python多装饰器针对函数、类、方法的调用顺序说明
- 06-24Python Qt GUI设计:Python调用UI文件的两种方法(基础篇—3)
- 270℃Python短文,Python中的嵌套条件语句(六)
- 268℃python笔记:for循环嵌套。end=""的作用,图形打印
- 266℃PythonNet:实现Python与.Net代码相互调用!
- 262℃Python实现字符串小写转大写并写入文件
- 261℃Python操作Sqlserver数据库(多库同时异步执行:增删改查)
- 121℃原来2025是完美的平方年,一起探索六种平方的算吧
- 101℃Python 和 JavaScript 终于联姻了!PythonMonkey 要火?
- 96℃Ollama v0.4.5-v0.4.7 更新集合:Ollama Python 库改进、新模型支持
- 最近发表
-
- Python调用Docker API的使用方式(pycharm docker 调试)
- 青少年Python编程系列28:Python中函数的递归调用
- python调用sqlite数据库案例(python 调用数据库)
- 【Python机器学习系列】基于Flask来构建API调用机器学习模型服务
- 通过pybind11来实现python调用C++接口(一)
- Python编程调用Deepseek API创建智能体
- python多装饰器针对函数、类、方法的调用顺序说明
- Python Qt GUI设计:Python调用UI文件的两种方法(基础篇—3)
- Python | Django 外部脚本调用 models 数据库
- 自学Python第九天——操作列表(python操作步骤)
- 标签列表
-
- python中类 (31)
- python 迭代 (34)
- python 小写 (35)
- python怎么输出 (33)
- python 日志 (35)
- python语音 (31)
- python 工程师 (34)
- python3 安装 (31)
- python音乐 (31)
- 安卓 python (32)
- python 小游戏 (32)
- python 安卓 (31)
- python聚类 (34)
- python向量 (31)
- python大全 (31)
- python次方 (33)
- python桌面 (32)
- python总结 (34)
- python浏览器 (32)
- python 请求 (32)
- python 前端 (32)
- python验证码 (33)
- python 题目 (32)
- python 文件写 (33)
- python中的用法 (32)