Python坐标计算(python坐标轴位置)
off999 2024-10-24 12:34 75 浏览 0 评论
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)))
更多学习资料请关注公众号“读书同友会”
相关推荐
- 大白菜一键装机win7系统(大白菜装系统教程win7)
-
1.电脑开机按f2或del进bios里面,启动项里面设置U盘启动,保存退出重启。2.键盘上一直按f12或f10,选择大白菜的u盘,进入pe界面,键盘按上下健移动,选择2003pe或win10pe,按回...
- 电脑windows密钥怎么查(windows密钥怎么看)
-
Win10系统查看并激活产品密钥的方法为:1、首先、进入到电脑屏幕的首页,在左上角会看到界面首页的“此电脑”选项。2、右键单次点击“此电脑”选项,在弹出的菜单快捷栏中选择最下方的“性”选项,并进行点击...
- 深度技术ghost xp sp3 如何安装
-
1、ghostxpsp3快速装机版使用ghost镜像来安装。方便快捷易操作。2、电脑开机进入bios后设置成光驱启动。设置方法参阅主板说明书。3、放入安装光盘后保存退出。电脑自动重启后光盘开始引导...
- win7安装卡在正在为首次使用
-
有可能是配置比较多,你可以耐心等待一会儿,如果实在不行就恢复原来的操作,然后使用U盘安装系统。1、到微软官网下载Windows10的系统光盘映象文件。2、然后用微软官方的系统U盘制作工具,将系统光盘...
- 用启动盘怎么安装系统(启动盘装系统win10步骤)
-
首先,需要准备一个启动盘,可以是U盘或光盘。将启动盘插入电脑,重启电脑并按下启动键,进入BIOS设置,将启动顺序改为从启动盘启动。保存设置并退出BIOS,电脑会重启并进入安装界面。选择安装语言和时区,...
- 华为手机怎么换桌面壁纸(华为壁纸怎么设置)
-
1、打开手机设置,点击“显示”。2、选择“壁纸”。3、将“随机切换桌面壁纸”后面的选项打开。4、点击上面的“设置壁纸”。5、我们发现最下方一排的图片可以切换,这一排图片就是壁纸相册。6、回到上一个界面...
- win7系统重装后没声音(win7系统重装没声音怎么解决)
-
检查电脑音频设备是否有问题,排查无问题后检查电脑声卡驱动,安装第三方驱动软件工具,这里以驱动精灵为例,安装后对电脑驱动进行查找,将声卡驱动安装或者升级即可电脑重装系统后没有声音可能是因为系统驱动程序没...
- 移动硬盘读不出(移动硬盘读不出来如何修复)
-
方法一1、首先右键此电脑,打开“管理”2、接着进入左边的“磁盘管理”3、然后右键“磁盘1”下的磁盘,点击“更改驱动器号和路径”4、随后在其中“更改”一下驱动器号,如果没有现成的就“添加”一个。5、设置...
- 2025十佳笔记本排行(2021年十大最佳笔记本)
-
2021年,笔记本电脑用什么CPU最好用?当然是艾灸系列最新12代的CPU最好用,也需要根据他的具体配置搭配什么样的主板和显卡,按成熟度来说,还是选择次心大的笔记本CPU比较好,因为硬件搭配也是202...
- 手机谷歌浏览器(手机谷歌浏览器怎么关闭无痕模式)
-
使用手机chrome方法:1、打开手机上的谷歌浏览器2、点击打开后,找到右上角的三个小点,点开它,会看到“设置”3、点开设置,然后会出现“搜索引擎”4、点开“搜索引擎”然后选择“搜狗”。5、然后一步步...
- 千兆网对路由器有要求吗(千兆路由器对无线有用吗)
-
回答:虽然不是必须,但是建议采用千兆路由器。只有使用千兆路由器,才能达到1000M光纤的最高网速。当使用旧的百兆路由器情况下,千兆带宽只能达到百兆网速。不能充分利用带宽,这样对您的千兆互联网光纤带宽...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
慕ke 前端工程师2024「完整」
-
失业程序员复习python笔记——条件与循环
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
