我正在处理需要在Python中转换为日期的字符串。在正常情况下,我的字符串会有%d/%m/%Y %H:%M:%S
。例如:18/02/2013 09:21:14
但是,在某些情况下,我可以获得类似于%d/%m/%Y %H:%M:%S:%ms
的东西,例如:06/01/2014 09:52:14:78
我想摆脱那个ms
位,但我需要弄清楚怎么做。我已经能够创建一个正则表达式,它可以测试日期是否匹配:
mydate = re.compile("^((((31\/(0?[13578]|1[02]))|((29|30)\/(0?[1,3-9]|1[0-2])))\/(1[6-9]|[2-9]\d)?\d{2})|(29\/0?2\/(((1[6-9]|[2-9]\d)?(0[48]|[2468][048]|[13579][26])|((16|[2468][048]|[3579][26])00))))|(0?[1-9]|1\d|2[0-8])\/((0?[1-9])|(1[0-2]))\/((1[6-9]|[2-9]\d)?\d{2})) (20|21|22|23|[0-1]?\d):[0-5]?\d:[0-5]?\d$")
s = "06/01/2014 09:52:14:78"
bool(mydate.match(s))
>>> False
但是我不知道如何才能得到有趣的部分,即06/01/2014 09:52:14
有什么想法吗?
发布于 2014-11-28 14:38:00
您可以使用正向后视和re.sub()
>>> re.sub(r'(?<=\d{2}:\d{2}:\d{2}).*','','06/01/2014 09:52:14:78')
'06/01/2014 09:52:14'
发布于 2014-11-28 14:38:20
re.sub
函数怎么样?
>>> re.sub(r'( \d{2}(:\d{2}){2}).*$',r'\1','06/01/2014 09:52:14:78')
'06/01/2014 09:52:14'
>>> re.sub(r'( \d{2}(:\d{2}){2}).*$,r'\1','8/02/2013 09:21:14')
'8/02/2013 09:21:14'
( \d{2}(:\d{2}){2}) matches
小时数:min:秒保存在捕获组1中.*$
匹配毫秒r'\1'
替换为第一个caputre组的内容https://stackoverflow.com/questions/27190911
复制相似问题