我想要一个regexp来匹配HH:MM格式的时间。以下是我所拥有的,而且它很有效:

^[0-2][0-3]:[0-5][0-9]$

它匹配从00:00到23:59的所有内容。

但是,我想改变它,所以0:00和1:00等也匹配,以及00:00和01:30。也就是说,让最左边的数字是可选的,以匹配HH:MM和H:MM。

有什么想法可以改变吗?我需要这个工作在javascript以及php。


当前回答

您的代码将无法正常工作,因为它不能用于01:00类型格式。您可以修改如下。

pattern =r"^(0?[1-9]|1[0-2]):[0-5][0-9]$"

为了不那么复杂,我们可以使用一个变量来定义我们的工作时间限制。此外,我们可以添加经络以获得更准确的结果。

hours_limit = 12 
pattern = r"^[1-hours_limit]:[0-5][0-9]\s?[AaPp][Mm]$"
print(re.search(pattern, "2:59 pm"))

其他回答

令人惊讶的是,我发现实际上所有这些都不能完全覆盖它,因为它们不适用于0:0的较短格式的午夜,一些也不适用于00:00,我使用并测试了以下内容:

^([0-9]|0[0-9]|1?[0-9]|2[0-3]):[0-5]?[0-9]$

你可以试试下面的方法

^\d{1,2}([:.]?\d{1,2})?([ ]?[a|p]m)?$

它可以检测以下模式:

2300 
23:00 
4 am 
4am 
4pm 
4 pm
04:30pm 
04:30 pm 
4:30pm 
4:30 pm
04.30pm
04.30 pm
4.30pm
4.30 pm
23:59 
0000 
00:00

上面的答案对我都没用,下面这个有用。

"[0-9]{2}:[0-9]{2}"

我的是:

^ (1? [0-9] [0, 3] | 2) : [0 to 5] [0-9] $

这个要短得多

用几个例子进行了测试

匹配:

00:00 7:43 07:43 19:00 18:23

并且不匹配任何无效的实例,如25:76等…

你可以使用以下正则表达式:

^[0-1][0-9]:[0-5][0-9]$|^[2][0-3]:[0-5][0-9]$|^[2][3]:[0][0]$