[英]Find difference between two dates in years, with the remainder expressed in days, in Python
如果 output 應該以年表示,余數以天表示,如何找到兩個日期之間的差異?
示例 1 :如果這兩個日期分別是June 1, 1981
和August 23, 2001,
那么結果應該是20 years and 83 days
。
示例 2 :如果兩個日期分別為January 1, 2002
和December 30, 2003,
則結果應為1 year and 363 days
。
我不關心結果的格式; 我只需要知道計算年數和天數的最 Pythonic 方式。
謝謝!
使用內置模塊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 個月是 6 個 31 天的月份、4 個 30 天的月份和一個 28 天的月份的混合。 所以,一般來說,你不能用它來獲取天數。 我建議編寫 function 以獲得所需形式的差異。
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'
您需要使用 datetime 和 relativedelta 模塊。
import datetime
from dateutil.relativedelta import relativedelta
start_date = datetime.datetime(1981,6,1)
end_date = datetime.datetime(2002,1,1)
difference_in_years = relativedelta(end_date, start_date)
print(difference_in_years)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.