我有一个提醒应用程序,我需要像一样打发时间3:30 a.m.。我使用了re模块,但是失败了。
我想做的是在列表中的单词前面按冒号分隔时间。但是列表有多个单词。像一样 a.m.,am 程序应尝试输入单词直到获得正确的匹配,然后用冒号分隔时间。
以小时和分钟为单位。13:25至[13,25]
这是一个例子:import ream = ['a.m.', 'am', 'ante meridiem']timeinp = 'reminder for 3:30 am'for a in am:
gettime = re.search(fr'\b\d?\d:\d\d\b {a}', timeinp).group(0)
gettime = re.split('[:]', gettime)
print(gettime)
这段代码给了我AttributeError: 'NoneType' object has no attribute 'group'。请帮忙。
如果存在匹配项,则可以将单个正则表达式与捕获组一起使用以立即访问小时和分钟:import ream = ['a.m.', 'am', 'ante meridiem']timeinp = 'reminder for 3:30 am'a = "|".join(map(re.escape, am))gettime = re.search(fr'\b(\d?\d):(\d\d)\s*(?:{a})', timeinp)if gettime:
print(list(map(int, gettime.groups()))) # => [3, 30]else:
print("no match")
请注意,gettime.groups()其中包含一个元组,其中包含匹配的所有子组,从1到模式中的许多组。捕获组是用括起来的所有模式部分(...)。
您需要列出re.escape您的am项目,否则,请.匹配任何字符。您需要\.在字符类外部使用以匹配文字点。
在尝试获取组0之前,请确保其匹配:for a in am:
gettime = re.search(fr'\b\d?\d:\d\d\b {a}', timeinp)
if gettime: # if matched (i.e. is not None)
gettime = re.split('[:]', gettime.group(0))
print(gettime)
编辑:
为了仅获取数字,请在括号中将其分组并通过组1进行访问:for a in am:
gettime = re.search(fr'\b(\d?\d:\d\d)\b {a}', timeinp)
if gettime:
gettime = re.split('[:]', gettime.group(1))
print(gettime)
转载请注明来源:soword科技言免费资源网站(www.soword.cn)
如有侵权麻烦联系我们:sowordkjy@gmail.com