以下是一个示例代码,演示了如何判断两个日期范围是否有重叠或包含关系:
import datetime
def check_date_overlap(start_date1, end_date1, start_date2, end_date2):
# 将日期字符串转换为datetime对象
start_date1 = datetime.datetime.strptime(start_date1, "%Y-%m-%d")
end_date1 = datetime.datetime.strptime(end_date1, "%Y-%m-%d")
start_date2 = datetime.datetime.strptime(start_date2, "%Y-%m-%d")
end_date2 = datetime.datetime.strptime(end_date2, "%Y-%m-%d")
# 检查是否有重叠或包含关系
if (start_date1 <= start_date2 <= end_date1) or (start_date1 <= end_date2 <= end_date1):
return True
elif (start_date2 <= start_date1 <= end_date2) or (start_date2 <= end_date1 <= end_date2):
return True
else:
return False
# 示例用法
date_range1_start = "2022-01-01"
date_range1_end = "2022-01-10"
date_range2_start = "2022-01-05"
date_range2_end = "2022-01-15"
if check_date_overlap(date_range1_start, date_range1_end, date_range2_start, date_range2_end):
print("日期范围有重叠或包含关系")
else:
print("日期范围没有重叠或包含关系")
在上述示例中,我们定义了一个check_date_overlap
函数来检查两个日期范围是否有重叠或包含关系。该函数首先将日期字符串转换为datetime
对象,然后使用比较运算符检查两个日期范围的关系。如果有重叠或包含关系,则返回True
,否则返回False
。
注意:在实际应用中,你需要根据具体的需求和数据结构来调整代码。上述示例是基于Python语言的,如果你使用的是其他编程语言,可以根据相应语言的日期处理和逻辑判断功能来实现类似的功能。