python 獲取日期列表中缺失的日期


獲取日期列表中缺失的日期

  最近有個需求,就是有一個時間段的日期格式的字符串列表,其中有缺失的日期,想要寫一個腳本來查出缺失的日期,算是個小工具,直接上代碼。

import datetime def get_no_date(date_str_li, start_date='', end_date=''): """獲取沒有列表中沒有包含的的日期區間的日期 args: start_date: 查詢的起始日期字符串,默認為date_li中最小值 end_date: 查詢的終止日期的字符串, 默認為date_li中最大值 date_str_li: 所有需要查詢的日期的列表 """
    if not date_str_li: raise ValueError('list can\'t empty') # 所有文件名稱,日期的列表
    try: date_li = [datetime.datetime.strptime(date_time, '%Y-%m-%d') for date_time in date_str_li] except: raise ValueError('your values can\'t be converted') if end_date: date_end = datetime.datetime.strptime(end_date, '%Y-%m-%d') else: date_end = max(date_li) if start_date: date_start = datetime.datetime.strptime(start_date, '%Y-%m-%d') else: date_start = min(date_li) no_list = [] while True: if date_end not in date_li: no_list.append(date_end) if date_end == date_start: break date_end -= datetime.timedelta(1) return [datetime.date.strftime(day, '%Y-%m-%d') for day in no_list]

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM