我正在编写一个涉及让用户按以下格式输入时间的应用程序:
1m30s # 1 Minute, 30 Seconds
3m15s # 3 Minutes, 15 Seconds
2m25s # 2 Minutes, 25 Seconds
2m # 2 Minutes
55s # 55 Seconds
Run Code Online (Sandbox Code Playgroud)
数据可以具有单个"分钟指定",单个"第二指定"或两者.将这些字符串解析为类似于以下格式的正确方法是什么?
{
"minutes" : 3
"seconds" : 25
}
Run Code Online (Sandbox Code Playgroud)
import re
tests=['1m30s','3m15s','2m25s','2m','55s']
for time_str in tests:
match=re.match('(?:(\d*)m)?(?:(\d*)s)?',time_str)
if match:
minutes = int(match.group(1) or 0)
seconds = int(match.group(2) or 0)
print({'minutes':minutes,
'seconds':seconds})
# {'seconds': 30, 'minutes': 1}
# {'seconds': 15, 'minutes': 3}
# {'seconds': 25, 'minutes': 2}
# {'seconds': 0, 'minutes': 2}
# {'seconds': 55, 'minutes': 0}
Run Code Online (Sandbox Code Playgroud)
正规救援!
>>> import re
>>> minsec = re.compile(r'(?P<minutes>\d+)m(?P<seconds>\d+)s')
>>> result = minsec.match('1m30s')
>>> result.groupdict()
{'seconds': '30', 'minutes': '1'}
Run Code Online (Sandbox Code Playgroud)
编辑:这是一个修订的解决方案:
import re
pattern = r'(?:(?P<minutes>\d+)m)?(?:(?P<seconds>\d+)s)?'
minsec = re.compile(pattern)
def parse(s, pat=minsec):
return pat.match(s).groupdict()
tests = ['1m30s', '30s', '10m29s']
for t in tests:
print '---'
print ' in:', t
print 'out:', parse(t)
Run Code Online (Sandbox Code Playgroud)
输出:
---
in: 1m30s
out: {'seconds': '30', 'minutes': '1'}
---
in: 30s
out: {'seconds': '30', 'minutes': None}
---
in: 10m29s
out: {'seconds': '29', 'minutes': '10'}
Run Code Online (Sandbox Code Playgroud)