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)
我也尝试过先行表达式,但它们无法正常工作。
欢迎任何其他解决方案
最佳答案
我建议避免使用正则表达式来尝试从字符串中提取日期。如果已知可能格式的数量,则只需尝试转换为 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
这具有跳过非法日期(例如 2018-09-31
)的好处,并且可以正确处理闰年。它也更容易遵循。
关于python - 我应该如何在不考虑 Python 顺序的情况下查找日期和时间?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51872721/