我想要一个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。


当前回答

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

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

其他回答

你可以使用这个正则表达式:

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

如果要排除00:00,可以使用这个表达式

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

第二个表达式是更好的选择,因为有效时间是00:01到00:59或0:01到23:59。您可以根据需要使用其中任何一种。 Regex101链接

声明

private static final String TIME24HOURS_PATTERN = "([01]?[0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9]";

public boolean validate(final String time) {
    pattern = Pattern.compile(TIME24HOURS_PATTERN);
    matcher = pattern.matcher(time);
    return matcher.matches();
}

当String与正则表达式匹配时,此方法返回“true”。

试试下面的方法

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

注意:我假设是javascript的正则表达式引擎。如果与此不同,请告诉我。

检查这个masterfull时间戳检测器正则表达式,我建立寻找用户指定的时间戳,它将拾取的例子包括,但绝对不限于;

8:30-9:40
09:40-09 : 50
09 : 40-09 : 50
09:40 - 09 : 50
08:00to05:00
08 : 00to05 : 00
08:00 to 05:00
8am-09pm
08h00 till 17h00
8pm-5am
08h00,21h00
06pm untill 9am

它还会拾取更多,只要times包含数字

看看这个

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