正则表达式中正向预查和负向预查如何区分应用?
- 内容介绍
- 文章标签
- 相关推荐
本文共计906个文字,预计阅读时间需要4分钟。
本文例举了正则表达式中的正向预查和负向预查的应用。分享给家长参考。
具体分析如下:
首先,来看一个例子,再解释什么是正向预查。
例子:有一段内容为coming soon, going的文本。
解释:正向预查是指查找在某个位置之后立即出现的特定字符或模式。在这个例子中,正向预查可以用来查找文本中going后面是否紧跟其他字符。
正向预查的表示方式为:(?=\text{模式}),其中模式是需要预查的字符或字符串。
例如,要查找going后面是否紧跟任意字符,可以使用以下正则表达式:
going(?=.)
其中,`.`代表任意字符。
负向预查则相反,是指查找在某个位置之后不出现特定字符或模式的情况。
负向预查的表示方式为:(?!\text{模式}),其中模式是需要预查的字符或字符串。
例如,要查找going后面不紧跟going,可以使用以下正则表达式:
going(?!\bgoing\b)
其中,`\b`代表单词边界,确保going是独立单词。
通过以上例子,我们可以看出正向预查和负向预查在正则表达式中的应用,帮助我们在文本中快速定位特定模式。
本文实例讲述了正则表达式中的正向预查和负向预查。分享给大家供大家参考。具体分析如下:
这里先来看一个例子,再来解释什么是正向预查。
例子:有一段内容为"coming soon,going gogogo",要求把com和go查找出来。代码如下:
复制代码 代码如下:<html>
<head>
<script type="text/javascript">
//正向预查
function t1(){
var con = document.getElementsByName('content')[0].value;
var reg = /\b[\w]+(?=ing\b)/g;//匹配带ing的单词,但是不要ing。注意:如果ing后不加\b,类似于goingabc也会匹配。
alert(con.match(reg));
}
</script>
</head>
<body>
<textarea rows="5" cols="30" name="content"></textarea><br />
<button onclick="t1();">正则预查</button><br />
</body>
</html>
以上面的实例来讲解正向预查:先查出边界,再找到与[\w]+匹配的字,(?=ing)表示先向后探测,看看有没有ing。如果有,则把前面的匹配出来;如果没有,则光标往后移一位,继续探测。这个过程就是正向预查:预先判断为某个值 。
所谓负向预查,就是预先判断不为某个值。文本框输入内容为"win7,winxp,win95,win98,win2003"
复制代码 代码如下:<html>
<head>
<script type="text/javascript">
//正向预查
function t1(){
var con = document.getElementsByName('content')[0].value;
var reg = /\bwin(?!95\b)/g;//
alert(con.match(reg));
}
</script>
</head>
<body>
<textarea rows="5" cols="30" name="content"></textarea><br />
<button onclick="t1();">正则预查</button><br />
</body>
</html>
上面两个例子是从前往后正向/负向预查----相关信息百度搜索"零宽断言"。JS不支持向前正向/负向预查,而PHP支持。
希望本文所述对大家的正则表达式学习有所帮助。
本文共计906个文字,预计阅读时间需要4分钟。
本文例举了正则表达式中的正向预查和负向预查的应用。分享给家长参考。
具体分析如下:
首先,来看一个例子,再解释什么是正向预查。
例子:有一段内容为coming soon, going的文本。
解释:正向预查是指查找在某个位置之后立即出现的特定字符或模式。在这个例子中,正向预查可以用来查找文本中going后面是否紧跟其他字符。
正向预查的表示方式为:(?=\text{模式}),其中模式是需要预查的字符或字符串。
例如,要查找going后面是否紧跟任意字符,可以使用以下正则表达式:
going(?=.)
其中,`.`代表任意字符。
负向预查则相反,是指查找在某个位置之后不出现特定字符或模式的情况。
负向预查的表示方式为:(?!\text{模式}),其中模式是需要预查的字符或字符串。
例如,要查找going后面不紧跟going,可以使用以下正则表达式:
going(?!\bgoing\b)
其中,`\b`代表单词边界,确保going是独立单词。
通过以上例子,我们可以看出正向预查和负向预查在正则表达式中的应用,帮助我们在文本中快速定位特定模式。
本文实例讲述了正则表达式中的正向预查和负向预查。分享给大家供大家参考。具体分析如下:
这里先来看一个例子,再来解释什么是正向预查。
例子:有一段内容为"coming soon,going gogogo",要求把com和go查找出来。代码如下:
复制代码 代码如下:<html>
<head>
<script type="text/javascript">
//正向预查
function t1(){
var con = document.getElementsByName('content')[0].value;
var reg = /\b[\w]+(?=ing\b)/g;//匹配带ing的单词,但是不要ing。注意:如果ing后不加\b,类似于goingabc也会匹配。
alert(con.match(reg));
}
</script>
</head>
<body>
<textarea rows="5" cols="30" name="content"></textarea><br />
<button onclick="t1();">正则预查</button><br />
</body>
</html>
以上面的实例来讲解正向预查:先查出边界,再找到与[\w]+匹配的字,(?=ing)表示先向后探测,看看有没有ing。如果有,则把前面的匹配出来;如果没有,则光标往后移一位,继续探测。这个过程就是正向预查:预先判断为某个值 。
所谓负向预查,就是预先判断不为某个值。文本框输入内容为"win7,winxp,win95,win98,win2003"
复制代码 代码如下:<html>
<head>
<script type="text/javascript">
//正向预查
function t1(){
var con = document.getElementsByName('content')[0].value;
var reg = /\bwin(?!95\b)/g;//
alert(con.match(reg));
}
</script>
</head>
<body>
<textarea rows="5" cols="30" name="content"></textarea><br />
<button onclick="t1();">正则预查</button><br />
</body>
</html>
上面两个例子是从前往后正向/负向预查----相关信息百度搜索"零宽断言"。JS不支持向前正向/负向预查,而PHP支持。
希望本文所述对大家的正则表达式学习有所帮助。

