使用内置模块datetime,可以轻松获取天数。
>>> import datetime
>>> foo = datetime.date(2001, 8, 23) - datetime.date(1981, 6, 1)
>>> foo
datetime.timedelta(days=7388)
>>> foo.days
7388
>>> bar = datetime.date(2003, 12, 30) - datetime.date(2002, 1, 1)
>>> bar
datetime.timedelta(days=728)
>>> bar.days
728
dateutil 模块可以给你年数,但是月数也扔进去了。
>>> import datetime
>>> from dateutil.relativedelta import relativedelta
>>> relativedelta(datetime.date(2001, 8, 23), datetime.date(1981, 6, 1))
relativedelta(years=+20, months=+2, days=+22)
>>> relativedelta(datetime.date(2003, 12, 30), datetime.date(2002, 1, 1))
relativedelta(years=+1, months=+11, days=+29)
不过,在使用月份数时要小心。一个月不像一天一样被定义。上例中的 11 个月是六个 31 天月份、四个 30 天月份和一个 28 天月份的混合。所以,一般来说,你不能用它来获取天数。我建议编写一个函数来获得所需形式的差异。
import calendar
import datetime
from dateutil.relativedelta import relativedelta
def get_delta(date2, date1):
'''calculate the delta between two datetime.date objects (date2 the newer date)'''
number_of_leap_years = sum(1
for yr in range(date1.year, date2.year + 1)
if calendar.isleap(yr))
number_of_years = relativedelta(date2, date1).years
total_number_of_days = (date2 - date1).days
number_of_days = total_number_of_days
- 365 * number_of_years
- number_of_leap_years
return f'{number_of_years} years, {number_of_days} days'