如果我有两个约会(例如。'8/18/2008'和'9/26/2008'),怎样才能得到这两个日期之间的天数?


当前回答

还有一个尚未提到的datetime.toordinal()方法:

import datetime
print(datetime.date(2008,9,26).toordinal() - datetime.date(2008,8,18).toordinal())  # 39

https://docs.python.org/3/library/datetime.html#datetime.date.toordinal

date.toordinal () 返回日期的预期格里高利历序数,其中第一年的1月1日序数为1。对于任意日期对象d, Date.fromordinal (d.toordinal()) == d。

似乎很适合计算日差,但可读性不如timedelta.days。

其他回答

每个人都用日期回答得很好, 让我用熊猫来回答这个问题

dt = pd.to_datetime('2008/08/18', format='%Y/%m/%d')
dt1 = pd.to_datetime('2008/09/26', format='%Y/%m/%d')

(dt1-dt).days

这就会给出答案。 如果其中一个输入是dataframe列。简单地使用dt。日子换成了日子

(dt1-dt).dt.days

在python中不使用datetime对象。

# A date has day 'd', month 'm' and year 'y' 
class Date:
    def __init__(self, d, m, y):
            self.d = d
            self.m = m
            self.y = y

# To store number of days in all months from 
# January to Dec. 
monthDays = [31, 28, 31, 30, 31, 30,
                                            31, 31, 30, 31, 30, 31 ]

# This function counts number of leap years 
# before the given date 
def countLeapYears(d):

    years = d.y

    # Check if the current year needs to be considered 
    # for the count of leap years or not 
    if (d.m <= 2) :
            years-= 1

    # An year is a leap year if it is a multiple of 4, 
    # multiple of 400 and not a multiple of 100. 
    return int(years / 4 - years / 100 + years / 400 )


# This function returns number of days between two 
# given dates 
def getDifference(dt1, dt2) :

    # COUNT TOTAL NUMBER OF DAYS BEFORE FIRST DATE 'dt1' 

    # initialize count using years and day 
    n1 = dt1.y * 365 + dt1.d

    # Add days for months in given date 
    for i in range(0, dt1.m - 1) :
            n1 += monthDays[i]

    # Since every leap year is of 366 days, 
    # Add a day for every leap year 
    n1 += countLeapYears(dt1)

    # SIMILARLY, COUNT TOTAL NUMBER OF DAYS BEFORE 'dt2' 

    n2 = dt2.y * 365 + dt2.d
    for i in range(0, dt2.m - 1) :
            n2 += monthDays[i]
    n2 += countLeapYears(dt2)

    # return difference between two counts 
    return (n2 - n1)


# Driver program 
dt1 = Date(31, 12, 2018 )
dt2 = Date(1, 1, 2019 )

print(getDifference(dt1, dt2), "days")

如果您没有日期处理库(或者您怀疑它有bug),这里有一个抽象算法,应该可以很容易地翻译成大多数语言。

在每个日期执行以下计算,然后简单地减去两个结果。所有的商和余数都是正整数。

步骤a:首先确定日期的部分为Y(年),M(月)和D(日)。这些变量会随着我们的进行而改变。

步骤b: M减去3

(所以一月是-2,十二月是9)。

步骤c:如果M是负的,M加12,Y减1。

(这将“一年的开始”更改为3月1日,月份编号为0(3月)到11(2月)。这样做的原因是为了“一年之内的天数”在闰年和普通年之间不会改变,这样“短”的月份就在一年的年底,所以下一个月就不需要特殊处理了。)

步骤D。 M除以5得到商Q₁,余数R₁。在d上增加Q₁× 153,下一步使用R₁。

(从3月1日开始,每5个月有153天。)

步骤E.将R₁除以2得到商Q₂,忽略余数。在D上加R₁× 31 - Q₂。

(在每组5个月中,每2个月有61天,每对月的第一个月为31天。忽略2月比30天短的事实是安全的,因为在这一点上你只关心2月1日的天数,而不是第二年的3月1日。)

步骤D & E组合-替代法

在第一次使用之前,设置L=[0,31,61,92,122,153,184,214,245,275,306,337]

(这是在每个月的第一天之前的(调整后的)年的累计天数。)

在D后面加上L[M]。

步骤F 如果你使用儒略历日期而不是公历日期,请跳过这一步;这个日期在不同的国家有所不同,但在大多数英语国家是1752年9月3日,在大多数欧洲国家是1582年10月4日。

如果您确定永远不需要处理1-Mar-1900到28-Feb-2100范围之外的日期,您也可以跳过这一步,但随后必须对您处理的所有日期做出相同的选择。

Y₃除以100,得到Q₃,余数R₃。将Q₃除以4,得到另一个商式Q₄,忽略余数。在D中加入Q₄+ 36524 × Q₃。

将R₃₃Y。

一步G。 将Y除以4得到商Q₅,并忽略其余部分。在D上增加Q₅+ 365 × Y。

步骤H.(可选) 您可以在D中添加您选择的常数,以强制某个特定日期具有特定的日号。

对每个日期执行步骤A~G,得到D₁和D₂。

我一步。 D₁与D₂相减,得到D₂在D₁后的天数。

最后,一个评论:在处理1760年之前的日期时要格外谨慎,因为对哪一个月是一年的开始没有一致意见;许多地方把3月1日作为新年。

如果您有两个date对象,您可以将它们相减,这将计算一个timedelta对象。

from datetime import date

d0 = date(2008, 8, 18)
d1 = date(2008, 9, 26)
delta = d1 - d0
print(delta.days)

文档的相关部分: https://docs.python.org/library/datetime.html。

请看另一个例子。

使用datetime函数:

from datetime import datetime
date_format = "%m/%d/%Y"
a = datetime.strptime('8/18/2008', date_format)
b = datetime.strptime('9/26/2008', date_format)
delta = b - a
print delta.days # that's it