我有一个提醒应用程序,我需要像一样打发时间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)