在日期列表中查找最近的过去日期

Jac*_*dge 3 python sorting datetime numpy

我试图在日期列表中找到距离当前日期最近的过去日期。我发现了几个在列表中搜索最近日期的示例,但所有这些都允许选择返回进一步的日期。

日期时间列表具有以下形式:

datelist =
[datetime.datetime(2019, 12, 31, 0, 0),
 datetime.datetime(2020, 1, 10, 0, 0),
 datetime.datetime(2020, 1, 20, 0, 0),
 datetime.datetime(2020, 1, 31, 0, 0),
 datetime.datetime(2020, 2, 10, 0, 0),
 datetime.datetime(2020, 2, 20, 0, 0)]
Run Code Online (Sandbox Code Playgroud)

到目前为止,我一直在实现以下函数来查找最接近的日期;

def nearest_ind(items, pivot):
    '''
    Find the nearest value to the given value (the pivot) in a list.
    '''
    time_diff = np.abs([date - pivot for date in items])
    return time_diff.argmin(0)
Run Code Online (Sandbox Code Playgroud)

但这会返回与当前日期最接近的日期,有一半的情况会返回未来最接近的日期。我也一直在考虑实现 numpy searchsorted 函数,但这似乎总是返回最近的未来日期,无论我为侧面参数选择“右”还是“左”,方法如下:

np.searchsorted(datelist, datetime.datetime.now(), side='right')
np.searchsorted(datelist, datetime.datetime.now(), side='left')
Run Code Online (Sandbox Code Playgroud)

在任一实例中,numpy searchsorted 函数都会返回(如果我今天运行它,即 2020 年 2 月 7 日)4(对应于 datetime.datetime(2020, 2, 10, 0, 0))。有谁知道如何确保始终返回过去最接近的日期?

Chr*_*ris 6

min与两个s 一起使用key是一种方法:

from datetime import datetime

now = datetime.now()
min(datelist, key=lambda x: (x>now, abs(x-now)) )
Run Code Online (Sandbox Code Playgroud)

输出:

datetime.datetime(2020, 1, 31, 0, 0)
Run Code Online (Sandbox Code Playgroud)