python 计算2个经纬度之间的直线距离

时间: 2023-11-06 13:05:59 浏览: 41
可以使用 haversine 公式来计算两个经纬度之间的直线距离。以下是一个计算两个经纬度之间距离的 Python 代码示例: ```python import math def distance(lat1, lon1, lat2, lon2): R = 6371 # 地球半径,单位为千米 dlat = math.radians(lat2-lat1) dlon = math.radians(lon2-lon1) a = math.sin(dlat/2) * math.sin(dlat/2) + math.cos(math.radians(lat1)) \ * math.cos(math.radians(lat2)) * math.sin(dlon/2) * math.sin(dlon/2) c = 2 * math.atan2(math.sqrt(a), math.sqrt(1-a)) d = R * c return d ``` 其中,`lat1` 和 `lon1` 是第一个点的纬度和经度,`lat2` 和 `lon2` 是第二个点的纬度和经度。函数返回值是两个点之间的距离(单位为千米)。
相关问题

两个经纬度之间的直线距离计算

计算两个经纬度之间的直线距离,可以使用 Haversine 公式,公式如下: d = 2 * r * arcsin(sqrt(sin²((lat₂-lat₁)/2) + cos(lat₁) * cos(lat₂) * sin²((lon₂-lon₁)/2))) 其中,d 表示两个经纬度之间的直线距离,r 表示地球半径,lat₁、lon₁ 和 lat₂、lon₂ 分别表示两个经纬度的纬度和经度。 在使用该公式计算距离时,需要将经纬度转换为弧度制。例如,如果使用度数表示经纬度,则需要将其转换为弧度制,公式如下: radian = degree * π / 180 其中,degree 表示度数,π 表示圆周率。 下面是用 Python 实现 Haversine 公式计算两个经纬度之间的直线距离的代码示例: ```python from math import sin, cos, sqrt, atan2, radians # 地球半径 R = 6371.0 # 两个经纬度的度数表示 lat1 = 52.2296756 lon1 = 21.0122287 lat2 = 52.406374 lon2 = 16.9251681 # 将经纬度转换为弧度制 lat1_r = radians(lat1) lon1_r = radians(lon1) lat2_r = radians(lat2) lon2_r = radians(lon2) # 计算经纬度之间的距离 d_lon = lon2_r - lon1_r d_lat = lat2_r - lat1_r a = sin(d_lat / 2)**2 + cos(lat1_r) * cos(lat2_r) * sin(d_lon / 2)**2 c = 2 * atan2(sqrt(a), sqrt(1 - a)) distance = R * c print("两个经纬度之间的距离:", distance, "km") ```

python已知经纬度求城市之间的直线距离

在Python中,可以使用haversine公式来计算两个地点之间的直线距离。Haversine公式是一种用于计算两个球面坐标之间距离的算法,可以用于计算两个经纬度坐标之间的距离。其公式如下: d = 2r * arcsin(sqrt(sin((lat2-lat1)/2)^2 + cos(lat1) * cos(lat2) * sin((lon2-lon1)/2)^2)) 其中,d是两个地点之间的距离,lat1,lon1是第一个地点的纬度和经度,lat2,lon2是第二个地点的纬度和经度,r是地球的平均半径,约为6371km。 因此,我们可以使用Python中的math库来计算两点之间的距离,并且使用的公式为Haversine公式。 下面是一个使用Python计算经纬度之间距离的例子: ```python from math import radians, cos, sin, asin, sqrt def calc_distance(lat1, lon1, lat2, lon2): # 转换经纬度为弧度 lon1, lat1, lon2, lat2 = map(radians, [lon1, lat1, lon2, lat2]) # Haversine公式计算距离 dlon = lon2 - lon1 dlat = lat2 - lat1 a = sin(dlat/2)**2 + cos(lat1) * cos(lat2) * sin(dlon/2)**2 c = 2 * asin(sqrt(a)) r = 6371 #地球半径,单位为公里 return c * r # 举例:计算北京和上海之间的距离 lat1, lon1 = 39.9042, 116.4074 # 北京的经纬度 lat2, lon2 = 31.2304, 121.4737 # 上海的经纬度 distance = calc_distance(lat1, lon1, lat2, lon2) print("北京和上海之间的距离为:",distance,"km") ``` 以上代码会输出:北京和上海之间的距离为: 1068.9046696384106 km 即北京和上海之间的大约距离为1068.9公里。

相关推荐

最新推荐

recommend-type

Python中如何利用经纬度进行距离计算

前些天由于工作中需求,要计算经纬度之间的距离,当我去网上搜索距离计算的方法时,发现很多文章中的方法乍一看都是很不同的,同是进行距离计算,为啥这么不一样呢?后来才发现问题在于很多文章没有进行相关的原理...
recommend-type

Python实现计算两个时间之间相差天数的方法

主要介绍了Python实现计算两个时间之间相差天数的方法,涉及Python针对日期时间的相关运算操作技巧,需要的朋友可以参考下
recommend-type

python计算机二级基础知识点复习.pdf

自己整理的笔记。关于python二级常用的一些函数,还有方法,还有python要考的第三方库的方法,用于python二级考试查看记忆用。
recommend-type

利用Python计算KS的实例详解

主要介绍了利用Python计算KS的实例详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

Python计算不规则图形面积算法实现解析

主要介绍了Python计算不规则图形面积算法实现解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

list根据id查询pid 然后依次获取到所有的子节点数据

可以使用递归的方式来实现根据id查询pid并获取所有子节点数据。具体实现可以参考以下代码: ``` def get_children_nodes(nodes, parent_id): children = [] for node in nodes: if node['pid'] == parent_id: node['children'] = get_children_nodes(nodes, node['id']) children.append(node) return children # 测试数
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。