首页 > 编程语言 >Python输入位置的坐标(即经纬度),计算两点的距离结果保留两位

Python输入位置的坐标(即经纬度),计算两点的距离结果保留两位

时间:2024-10-29 21:20:10浏览次数:9  
标签:distance lat1 经纬度 lat2 Python 坐标 lon1 lon2 math

可以使用haversine公式来计算两个坐标点之间的距离。以下是一个示例代码:

import math

def calculate_distance(lat1, lon1, lat2, lon2):
    # 将经纬度转换为弧度
    lon1 = math.radians(lon1)
    lat1 = math.radians(lat1)
    lon2 = math.radians(lon2)
    lat2 = math.radians(lat2)

    # 使用haversine公式计算距离
    dlon = lon2 - lon1
    dlat = lat2 - lat1
    a = math.sin(dlat/2)**2 + math.cos(lat1) * math.cos(lat2) * math.sin(dlon/2)**2
    c = 2 * math.atan2(math.sqrt(a), math.sqrt(1-a))
    distance = 6371 * c  # 地球半径为6371公里

    return round(distance, 2)

# 输入两个点的经纬度
lat1 = float(input("请输入第一个点的纬度:"))
lon1 = float(input("请输入第一个点的经度:"))
lat2 = float(input("请输入第二个点的纬度:"))
lon2 = float(input("请输入第二个点的经度:"))

# 计算两点之间的距离
distance = calculate_distance(lat1, lon1, lat2, lon2)
print("两点之间的距离为:", distance, "公里")

注意,该代码使用了math模块中的函数来进行数学运算,需要先进行导入。使用math.radians()函数将经纬度转换为弧度,然后应用haversine公式计算两点之间的距离。最后,使用round()函数将结果保留两位小数,以便输出。

标签:distance,lat1,经纬度,lat2,Python,坐标,lon1,lon2,math
From: https://blog.csdn.net/qq_25699299/article/details/143350545

相关文章

  • Python高手进阶:重写vs重载,你真的懂了吗?
    在面向对象编程中,“重写”与“重载”是两个核心概念,它们分别对应着如何扩展或改变现有功能的不同方式。尽管Python作为一种动态语言,对于这两种概念的支持与C++、Java等强类型静态语言有所不同,但这并不意味着它们在Python中不存在。01/ Python中的重写(Overwriting)重写,又......
  • 猴子请来的补丁——Python中的Monkey Patching
    猴子补丁(MonkeyPatching)在Python中是一种允许在运行时修改对象行为的技术。这种技术可以在不直接修改原始源代码的情况下,动态地改变或扩展程序的行为。猴子补丁的原理猴子补丁的核心原理是利用Python的动态特性,即在运行时修改对象(如函数、方法或类)的属性或行为。在Python......
  • Python从0到100(六十八):Python OpenCV-图像边缘检测及图像融合
    前言:零基础学Python:Python从0到100最新最全教程。想做这件事情很久了,这次我更新了自己所写过的所有博客,汇集成了Python从0到100,共一百节课,帮助大家一个月时间里从零基础到学习Python基础语法、Python爬虫、Web开发、计算机视觉、机器学习、神经网络以及人工智能相关知......
  • 用Python将 UE5内存分析日志 提取到Excel表
            上篇文章我们已经实现了 “使用Python批量提取文本中,当某一行存在 “×××××”时获取这一行文字,并将所有提取的内容按顺序保存到一个新的文件中”。而后来我发现这个功能已经不能满足我的需求了,所以本次我们将重新对一个更复杂文件的内容进行批量提......
  • 基于Python+Vue开发的鲜牛奶订购管理系统
    项目简介该项目是基于Python+Vue开发的鲜牛奶订购管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Python编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Python的牛奶订购管理系统项目,大学生可以在实践中学习和提......
  • 基于Python+Vue开发的民宿客房预订管理系统
    项目简介该项目是基于Python+Vue开发的民宿客房预订管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Python编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Python的民宿客房预订管理系统项目,大学生可以在实践中学......
  • 【Azure Bot Service】部署Python ChatBot代码到App Service中
    问题描述使用Python编写了ChatBot,在部署到AppService,却无法启动。通过高级工具(Kudu站点:https://<yoursitename>.scm.chinacloudsites.cn/newui)查看日志显示:Failedtofindattribute'app'in'app'.2024-10-25T02:43:29.242073529Z_____......
  • Python中使用共享变量+信号量实现进程间的实时通信
    【Python程序1中】importctypesimportposix_ipcimportmultiprocessingfrommultiprocessingimportshared_memory#如果系统中已经存在名为/semaphore1的信号量对象,Python并不会重新初始化它,而是使用现有的信号量,#导致现有的信号量可能有残留状态,使得acquire()一直阻......
  • [python]多线程快速入门
    前言线程是操作系统能够进行运算调度的最小单位,它被包含在进程之中,是进程中的实际运作单位。由于CPython的GIL限制,多线程实际为单线程,大多只用来处理IO密集型任务。Python一般用标准库threading来进行多线程编程。基本使用方式1,创建threading.Thread类的示例importthreadi......
  • python+flask框架的基于微信小程序的校园跑腿系统服务端视频8(开题+程序+论文) 计算机
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容选题背景随着移动互联网技术的快速发展,微信小程序作为一种轻量级的应用形式,已广泛应用于各类服务场景。在校园环境中,学生对于便捷生活服务的需求日......