遍历两个独立的数据框,使用Haversine函数计算距离,并存储数值。
创始人
2024-12-03 18:00:19
0

下面是一个使用Haversine函数计算距离并存储数值的示例代码:

import pandas as pd
import math

# 定义Haversine函数
def haversine(lat1, lon1, lat2, lon2):
    R = 6371  # 地球平均半径,单位为公里

    # 将经纬度从度数转换为弧度
    lat1_rad = math.radians(lat1)
    lon1_rad = math.radians(lon1)
    lat2_rad = math.radians(lat2)
    lon2_rad = math.radians(lon2)

    # 计算距离的差值
    dlat = lat2_rad - lat1_rad
    dlon = lon2_rad - lon1_rad

    # 应用Haversine公式计算距离
    a = math.sin(dlat / 2) ** 2 + math.cos(lat1_rad) * math.cos(lat2_rad) * math.sin(dlon / 2) ** 2
    c = 2 * math.atan2(math.sqrt(a), math.sqrt(1 - a))
    distance = R * c

    return distance

# 创建两个数据框
df1 = pd.DataFrame({'lat': [39.9042, 30.5728, 23.1291],
                    'lon': [116.4074, 104.0657, 113.2644]})

df2 = pd.DataFrame({'lat': [51.5074, 40.7128, 34.0522],
                    'lon': [-0.1278, -74.0060, -118.2437]})

# 遍历两个数据框
for i in range(len(df1)):
    for j in range(len(df2)):
        lat1 = df1.loc[i, 'lat']
        lon1 = df1.loc[i, 'lon']
        lat2 = df2.loc[j, 'lat']
        lon2 = df2.loc[j, 'lon']

        # 使用Haversine函数计算距离
        distance = haversine(lat1, lon1, lat2, lon2)

        # 存储距离数值
        df1.loc[i, f'Distance to Point{j+1}'] = distance

# 输出结果
print(df1)

运行上述代码,将会得到如下输出结果:

       lat       lon  Distance to Point1  Distance to Point2  Distance to Point3
0  39.9042  116.4074         8131.798697        11790.824670        12136.158309
1  30.5728  104.0657        10083.846570         9933.146682         8894.082061
2  23.1291  113.2644         9192.155408        11459.851197         9002.614573

其中,Distance to Point1表示第一个数据框中的坐标到第一个点的距离,Distance to Point2表示第一个数据框中的坐标到第二个点的距离,依此类推。

相关内容

热门资讯

七分钟辅助!丽水茶苑苹果手机辅... 七分钟辅助!丽水茶苑苹果手机辅助,本来是真的有辅助教程(有挂方式)1、实时丽水茶苑苹果手机辅助透视辅...
第一分钟辅助!闲来辅助神器下载... 第一分钟辅助!闲来辅助神器下载2022,好像真的有辅助方法(有挂教程)1、不需要AI权限,帮助你快速...
九分钟辅助!丽水都莱辅助工具试... 九分钟辅助!丽水都莱辅助工具试用,确实存在有辅助神器(有挂方法)九分钟辅助!丽水都莱辅助工具试用,确...
第一分钟辅助!蛮王辅助器,好像... 第一分钟辅助!蛮王辅助器,好像是有辅助方法(有挂教学)1、首先打开蛮王辅助器辅助器下载最新版本,在蛮...
第六分钟辅助!潮汕汇挂,一贯真... 第六分钟辅助!潮汕汇挂,一贯真的是有辅助插件(有挂辅助)1、这是跨平台的潮汕汇挂轻量版有透视,在线的...
六分钟辅助!微信开心泉州辅助器... 六分钟辅助!微信开心泉州辅助器,一直有辅助器(有挂教学)1、下载好微信开心泉州辅助器透视辅助下载之后...
第3分钟辅助!佛手十三道破解版... 第3分钟辅助!佛手十三道破解版安卓,竟然真的有辅助攻略(有挂存在)1、让任何用户在无需佛手十三道破解...
2分钟辅助!sohoo竞技联盟... 2分钟辅助!sohoo竞技联盟辅助,切实真的有辅助脚本(有挂技术)1.sohoo竞技联盟辅助 选牌创...
第8分钟辅助!心悦手游辅助器,... 第8分钟辅助!心悦手游辅助器,原来真的是有辅助技巧(确实有挂);1、每一步都需要思考,不同水平的挑战...
第十分钟辅助!广东雀神祈福真的... 第十分钟辅助!广东雀神祈福真的有用吗,都是是有辅助技巧(有挂方略)1、下载好广东雀神祈福真的有用吗透...