之前在 edabit 做练习时遇到题目,遇到这个问题发现不懂!
搜了文章
(pattern) : 匹配 pattern 并获取这一匹配,所获取的匹配可以从产生的 Matches 集合得到。
(?:pattern) :匹配 pattern 但不获取匹配结果,也就是说这是一个非获取匹配,不进行存储供以后使用。
(?=pattern) :正向预查,在任何匹配 pattern 的字符串开始处匹配查找字符串。这是一个非获取匹配,也就是说,该匹配不需要获取供以后使用。预查不消耗字符,也就是说,在一个匹配发生后,在最后一次匹配之后立即开始下一次匹配的搜索,而不是从包含预查的字符之后开始。
共同点
(?:pattern)
与 (?=pattern)
都匹配pattern,但不会把pattern结果放到Matches的集合中,即Matcher.group()不会匹配到(?;pattern)与(?=pattern)
区别
-
(?:pattern)
匹配得到的结果包含pattern,(?=pattern)
则不包含。如:对字符串:"industry abc"的匹配结果: 复制代码
var reg =/industr(?:y)/ var str="industry abc" str.match(reg); 输出:["industry", index: 0, input: "industry abc", groups: undefined]
var reg =/industr(?=y)/ var str="industry abc" str.match(reg); ["industr", index: 0, input: "industry abc", groups: undefined]
是否消耗字符
(?:pattern)
消耗字符,下一字符匹配会从已匹配后的位置开始。
(?=pattern)
不消耗字符,下一字符匹配会从预查之前的位置开始。
即后者只预查,不移动匹配指针。如:
下面在来个题目巩固一下:
题目:
创建一个特殊的正则表达式,以检测GET请求是否有效。
字符串的格式如下:
name1=val1&name2=val2&name3=val3&name4=val4
复制代码
您需要使用四个名称检测请求:“ val”,“ id”,“ desc”,“ time”(每个值可以具有不同的顺序)。
例如:
"val=val1&id=val2&desc=val3&time=val4"
"id=val2&val=val1&time=val4&desc=val3"
复制代码
每个名称都有一个特定的值:
-
**
val 可以包含字符串a到z和数字0到9(任何情况下都可以接受)。
**
-
**
id 是从0到10的数字。
**
-
**
desc 可以包含字符串a到z。
**
-
**
时间 是格式化值(00:00到99:99)。
**
例如:
"val=test1151&id=5&desc=helloWorld&time=54:33"
"id=10&val=123test&time=99:00&desc=itsok"
答案:
const regExp = /(?=.*&?desc=([a-zA-Z]+)(?:&\w|$))(?=.*&?val=([a-zA-Z0-9]+)(?:&\w|$))(?=.*&?time=(\d{2}:\d{2})(?:&\w|$))(?=.*&?id=(10|[0-9])(?:&\w|$))^[^&][^-]*[^&]$/;
function dataRegexLovely(str) {
var m = str.match(regExp);
return {
desc: m[1],
val: m[2],
time: m[3],
id: +m[4]
};
}
复制代码
文章来源:www.cnblogs.com/silver-airc…
匹配html 标签 var reg=/(?:<)([a-z1-9]+)[^<>/]*(?:>)/g;