在python中查找给定日期的间隔

2024-04-20 12:43:36 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在努力处理python中的日期对象。你知道吗

我有以下数据:

from datetime import datetime, timedelta 
# date retrieved from a list
ini =  [u'2016-01-01']
# transform the ini in a readable string
ini2 = ', '.join(map(str, ini))
# transform the string a date object
date_1 = datetime.strptime(ini2, "%Y-%m-%d")
# number that is the length of the date
l = 365.0
# adding l to ini2
final = date_1 + timedelta(days = l)

现在我需要将整个间隔(即从date_1final的时间段)分割成一个输入数字(例如ts=4),并给定另一个输入日期(例如new_date = u'2016-05-19'),检查它是哪个间隔(例如5月19日是t2=2)。你知道吗

我希望我说得够清楚。你知道吗

谢谢 我尝试了不同的方法,但似乎没有一个是正确的。你知道吗


Tags: the数据对象fromimportdatetimedatestring
3条回答

你可以用间隔的总秒数来计算。你知道吗

import math
from datetime import datetime, timedelta 

l = 365.0
factor = 4
date_1 = datetime.strptime('2016-01-01', "%Y-%m-%d")
lookup_dt = datetime.strptime('2016-12-01', "%Y-%m-%d")

def get_interval_num(factor, start_dt, td, lookup_dt):
    final = start_dt + td
    interval = (final - start_dt).total_seconds()
    subinterval = interval / factor
    interval_2 = (lookup_dt - start_dt).total_seconds()
    return int(math.ceil(interval_2 / subinterval))

num = get_interval_num(
    factor=factor,
    start_dt=date_1,
    td= timedelta(days=l),
    lookup_dt=lookup_dt
)
print("The interval number is: %s" % num)

输出为:

The interval number is: 4

编辑:清除变量命名,扩展代码段

这可能有助于:

from datetime import datetime, timedelta


def which_interval(date0, delta, date1, n_intervals):
    date0 = datetime.strptime(date0, '%Y-%m-%d')
    delta = timedelta(days = delta)
    date1 = datetime.strptime(date1, '%Y-%m-%d')
    delta1 = date1 - date0
    quadrile = int(((float(delta1.days) / delta.days) * n_intervals))
    return quadrile


# Example: figure out which quarter August 1st is in
interval = which_interval(
    '2016-01-01',
    366,
    '2016-08-01',
    4)
print '2016-08-01 is in interval %d, Q%d'%(interval, interval+1)

请注意,此函数使用python索引,因此它将从第0季度开始,到第3季度结束。如果需要基于1的索引(因此答案将是1、2、3或4),则需要在结果中添加1。你知道吗

timedelta对象支持除法,因此使用step的楼层除法,您将在range(ts)中得到一个间隔

new_date = datetime.strptime(u'2016-05-19', "%Y-%m-%d")

ts = 4
step = timedelta(days=l)/ts #divide by the number of steps

interval = (new_date - date_1)//step #get the number this interval is in

所以对于date_1 <= new_date < date_1 + step区间将是0,对于date_1+step<=new_date < date_1 + step*2区间将是1,以此类推

当然,这是使用python风格的索引,因此要获得从1开始的数字,请添加一个:

 interval = (new_date - date_1)//step + 1

EDIT:划分timedelta对象的功能仅在python3中添加,您需要使用.total_seconds()方法在python2中进行计算:

step = timedelta(days=l).total_seconds()/ts #divide by inteval

interval =  (new_date - date_1).total_seconds()//step

相关问题 更多 >