python 两个时间序列坐标点的平均航速计算 两个UTC时间差计算

计算两个UTC 时间差,返回两个UTC时间秒数
def caculateTimeDifference(lastTime, currentTime):
    '''
    计算两个UTC时间差,秒
    :param lastTime:
    :param currentTime:
    :return:
    '''
    ctime = time.localtime(currentTime)
    ltime = time.localtime(lastTime)
    ctimeStr = time.strftime("%Y-%m-%d %H:%M:%S", ctime)
    ltimeStr = time.strftime("%Y-%m-%d %H:%M:%S", ltime)
    # print(timeStr)
    a = parse(ctimeStr)
    b = parse(ltimeStr)
    # print((a - b).days)
    # print((a - b).seconds)
    # print((a - b).total_seconds())
    seconds = (a - b).total_seconds()
    # 1.days:来获取时间差的天数
    #
    # 2.seconds:来获取时间差中的秒数。注意,seconds获得的秒只是时间差中的小时、分钟和秒部分的和,并没有包含时间差的天数
    #
    # 3.total_seconds:来获取准确的时间差,并将时间差转换为秒
    return seconds

计算两个时间序列的坐标点的速度

from math import radians, cos, sin, asin, sqrt
import time
from dateutil.parser import parse
# 计算两个经纬度距离  单位为米
def haversine(lon1, lat1, lon2, lat2):  # 经度1,纬度1,经度2,纬度2 (十进制度数)
    """
    Calculate the great circle distance between two points
    on the earth (specified in decimal degrees)
    """
    # 将十进制度数转化为弧度
    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 * 1000


def caculateTimeDifference(lastTime, currentTime):
    '''
    计算两个UTC时间差,毫秒
    :param lastTime:
    :param currentTime:
    :return:
    '''
    ctime = time.localtime(currentTime)
    ltime = time.localtime(lastTime)
    ctimeStr = time.strftime("%Y-%m-%d %H:%M:%S", ctime)
    ltimeStr = time.strftime("%Y-%m-%d %H:%M:%S", ltime)
    # print(timeStr)
    a = parse(ctimeStr)
    b = parse(ltimeStr)
    # print((a - b).days)
    # print((a - b).seconds)
    # print((a - b).total_seconds())
    seconds = (a - b).total_seconds()
    # 1.days:来获取时间差的天数
    #
    # 2.seconds:来获取时间差中的秒数。注意,seconds获得的秒只是时间差中的小时、分钟和秒部分的和,并没有包含时间差的天数
    #
    # 3.total_seconds:来获取准确的时间差,并将时间差转换为秒
    return seconds


# 计算速度
def caculateSpeed(lastTime, lastPoint, currentTime, currentPoint):
    timeDifferences = caculateTimeDifference(lastTime, currentTime)
    # print(lastTime, currentTime, "----------", timeDifferences)
    distanceDifferences = haversine(lastPoint[1], lastPoint[0], currentPoint[1],
                                    currentPoint[0])  # lon1, lat1, lon2, lat2
    # print(distanceDifferences, "-----", timeDifferences)
    return distanceDifferences / timeDifferences*1000, timeDifferences
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值