Bor*_*elo 1 python regex datetime
import re
exp1="2018-7-12 13:00:00"
exp2="13:00:00 2018-7-12"
reg= r'\d\d\d\d[./-](0?[1-9]|1[0-2])[./-](0?[1-9]|[12][0-9]|3[01]) (00|[0- 9]|1[0-9]|2[0-3]):([0-9]|[0-5][0-9]):([0-9]|[0-5][0-9])'
compDate = re.search(reg,exp1)
Run Code Online (Sandbox Code Playgroud)
我也尝试了先行表达式,但他们没有让它们工作.
欢迎任何其他解决方案
我建议避免使用正则表达式尝试从字符串中提取日期.如果已知可能的格式数,则只需尝试转换为datetime对象.如果转换失败,请尝试下一种可能的格式.
例如:
from datetime import datetime
test_dates = ["2018-7-12 13:00:00", "13:00:00 2018-7-12"]
date_formats = ["%Y-%m-%d %H:%M:%S", "%H:%M:%S %Y-%m-%d"]
for date in test_dates:
for date_format in date_formats:
try:
dt = datetime.strptime(date, date_format)
print(dt)
except ValueError as e:
pass
Run Code Online (Sandbox Code Playgroud)
这有利于跳过非法日期,例如2018-09-31并正确处理闰年.它也更容易理解.