X-Git-Url: https://plomlompom.com/repos/feed.xml?a=blobdiff_plain;f=plomtask%2Fdating.py;h=711da95efabfc97153cca3c5d85eb63348244397;hb=8945aa6762977c04538c49c320417311b38232be;hp=e143fb652991780b994ef788b32a23c66b849120;hpb=f92de64d072009c8c4bf96b9eeb9fa245045662b;p=plomtask diff --git a/plomtask/dating.py b/plomtask/dating.py index e143fb6..711da95 100644 --- a/plomtask/dating.py +++ b/plomtask/dating.py @@ -1,5 +1,5 @@ """Various utilities for handling dates.""" -from datetime import datetime +from datetime import datetime, timedelta from plomtask.exceptions import BadFormatException DATE_FORMAT = '%Y-%m-%d' @@ -8,9 +8,18 @@ MAX_RANGE_DATE = '2030-12-31' def valid_date(date_str: str) -> str: - """Validate date against DATE_FORMAT or 'today', return in DATE_FORMAT.""" + """Validate date against DATE_FORMAT or 'today'/'yesterday'/'tomorrow. + + In any case, returns in DATE_FORMAT. + """ if date_str == 'today': date_str = todays_date() + elif date_str == 'yesterday': + date = datetime.now() - timedelta(days=1) + date_str = date.strftime(DATE_FORMAT) + elif date_str == 'tomorrow': + date = datetime.now() + timedelta(days=1) + date_str = date.strftime(DATE_FORMAT) try: dt = datetime.strptime(date_str, DATE_FORMAT) except (ValueError, TypeError) as e: