簡體   English   中英

在 Python 中查找兩個日期之間的年差,余數以天表示

[英]Find difference between two dates in years, with the remainder expressed in days, in Python

如果 output 應該以年表示,余數以天表示,如何找到兩個日期之間的差異?

示例 1 :如果這兩個日期分別是June 1, 1981August 23, 2001,那么結果應該是20 years and 83 days

示例 2 :如果兩個日期分別為January 1, 2002December 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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM