使用三个不同的日期类型库检查日期

Checking a date with three different date type libraries

我有一个不同日期的列表。我想测试列表中的值是否为有效日期。我曾尝试这样做,但我给出的声明效果不佳。我该怎么做?

list1 = ['201222020','20-12-2020','12122020', '53122020']
valid=[]
invalid=[]
for l in list1:
    try:
        x = dateutil.parser.parse(str(l)) or dt.strptime(str(l),'%m%d%Y') or dt.strptime(str(l),'%d%m%Y')
        valid.append(x)
    
    except:
        invalid.append(l)
print(valid)
print(invalid)

给出:

valid = [datetime.datetime(2020, 12, 20, 0, 0)]
invalid = ['201222020', '12122020', '53122020']

但在现实生活中,像这样的 '201222020','12122020' 日期也应该被接受,这是通过在 or 之后使用其他语句而发生的,并且这个值 '53122020' 应该被拒绝。

在我的场景中,它如上所示。我哪里错了?如何以正确的方式对齐语句,以便列表将一个接一个地检查 (first date until and then datetime('%m%d%Y') 然后 datetime('%d%m%Y') 由所有三个检查?

实际输出:

 valid = [datetime.datetime(2020, 20, 2, 0, 0), datetime.datetime(2020, 12, 20, 0, 0), datetime.datetime(2020, 12, 12, 0, 0)]
invalid = ['53122020']

您可以创建一个函数来尝试使用一组其他函数来解析输入。后面的函数可以是 dateutil.parser.parsedatetime.strptime 或您选择的任何内容。如果全部失败,则输入无效。

例如:

from datetime import datetime
import dateutil

def validate(datestring, vd_funcs, vd_args):
    """
    a function that tests if a datestring can be parsed by one of the functions
    supplied by vd_funcs. vd_args can be used to provide these funcs with additional
    arguments.
    """
    for f, a in zip(vd_funcs, vd_args):
        try:
            return f(datestring, *a) # see if the function works, return if so
        except ValueError:
            continue # try next
    else:
        return None # no function worked, invalid date string
    
# the functions you want to use to see if they parse the string    
vd_funcs = (dateutil.parser.parse, datetime.strptime, datetime.strptime)
# arguments to these functions, after passing the date string itself.
vd_args = ((None,), ('%m%d%Y',), ('%d%m%Y',))    

运行 这对于示例日期字符串列表给出

valid=[]
invalid=[]  
for s in ['201222020','20-12-2020','12122020', '53122020']:
    vd = validate(s, vd_funcs, vd_args)
    if vd:
        valid.append(vd)
    else:
        invalid.append(s)
    
valid
[datetime.datetime(2020, 12, 20, 0, 0), datetime.datetime(2020, 12, 12, 0, 0)]

invalid
['201222020', '53122020']