检查日期是否在两个日期之间,不包括年份



我有一个yyyy-mm-dd格式的datetime日期,我想检查输入的日期是否介于5月15日和5月25日之间,而不包含任何年份值。

tripDate_str = str(input("Please enter the trip start date in the following format: YYYY-MM-DD "))
import datetime
tripDate = datetime.datetime.strptime(tripDate_str, "%Y-%m-%d")

我想最简单的方法是使用月份和日期类属性

import datetime
tripDate = datetime.datetime.strptime('2022-05-15', "%Y-%m-%d")
start = datetime.datetime.strptime('2022-05-10', "%Y-%m-%d")
end = datetime.datetime.strptime('2022-05-20', "%Y-%m-%d")
if tripDate.month >= start.month and tripDate.month <= end.month and tripDate.day >= start.day and tripDate.day <= end.day:
print('Date in range')
else:
print('Date not in range')

有许多选项可以从日期中获得一年中的哪一天。使用关键字python day of year的搜索引擎来查找,或者查看这里的stackoverflow ("在python中将年/月/日转换为一年中的一天")。下面的代码用于此目的dateObject.timetuple().tm_yday:

tripDate_str = str(input("Please enter the trip start date in the following format: YYYY-MM-DD "))
# tripDate_str = "2022-05-18"
## Finding day of year
from datetime import date
tripDate = date(*map(int, tripDate_str.split('-')))
tripDate_dayOfYear = tripDate.timetuple().tm_yday
print("Day of year: ", tripDate_dayOfYear,  type(tripDate_dayOfYear))
dateRangeBeg_dayOfYear = date(tripDate.year, 5, 15).timetuple().tm_yday
dateRangeEnd_dayOfYear = date(tripDate.year, 5, 25).timetuple().tm_yday
if dateRangeBeg_dayOfYear <= tripDate_dayOfYear <= dateRangeEnd_dayOfYear:
print("tripDate falls into range", dateRangeBeg_dayOfYear, dateRangeEnd_dayOfYear)
else:
print("tripDate is outside range", dateRangeBeg_dayOfYear, dateRangeEnd_dayOfYear)

为避免闰年问题,在设置dateRangeBeg_dayOfYeardateRangeEnd_dayOfYear的值时使用tripDate.year

相关内容

  • 没有找到相关文章