Luí*_*rme 11 ruby python datetime parsing
我想解析一个可以预先知道的几种格式的日期.如果我无法解析,我会返回零.在ruby中,我喜欢这样:
DATE_FORMATS = ['%m/%d/%Y %I:%M:%S %p', '%Y/%m/%d %H:%M:%S', '%d/%m/%Y %H:%M', '%m/%d/%Y', '%Y/%m/%d']
def parse_or_nil(date_str)
parsed_date = nil
DATE_FORMATS.each do |f|
parsed_date ||= DateTime.strptime(date_str, f) rescue nil
end
parsed_date
end
Run Code Online (Sandbox Code Playgroud)
这是简洁而有效的.我怎样才能在Python中做同样的事情?
roo*_*oot 15
我会尝试dateutil.它可以识别大多数格式:
from dateutil import parser
parser.parse(string)
Run Code Online (Sandbox Code Playgroud)
如果你最终使用datetime.strptime建议@RocketDonkey:
from datetime import datetime
def func(s,flist):
for f in flist:
try:
return datetime.strptime(s,f)
except ValueError:
pass
Run Code Online (Sandbox Code Playgroud)
Roc*_*key 11
您可以使用try/except捕获ValueError尝试使用不匹配格式时会发生的情况.正如@Bakuriu所提到的,你可以在找到匹配时停止迭代以避免不必要的解析,然后在未定义时定义你的行为,my_date因为找不到匹配的格式:
您可以使用try/except捕获ValueError尝试使用不匹配格式时会发生的情况:
from datetime import datetime
DATE_FORMATS = ['%m/%d/%Y %I:%M:%S %p', '%Y/%m/%d %H:%M:%S', '%d/%m/%Y %H:%M', '%m/%d/%Y', '%Y/%m/%d']
test_date = '2012/1/1 12:32:11'
for date_format in DATE_FORMATS:
try:
my_date = datetime.strptime(test_date, date_format)
except ValueError:
pass
else:
break
else:
my_date = None
print my_date # 2012-01-01 12:32:11
print type(my_date) # <type 'datetime.datetime'>
Run Code Online (Sandbox Code Playgroud)