解析正则表达式中的.*,.*?,.+?的含义

所属分类: 网络编程 / 正则表达式 阅读数: 901
收藏 0 赞 0 分享

1. .*

. 表示匹配除换行符 \n 之外的任何单字符,*表示零次或多次。所以.*在一起就表示任意字符出现零次或多次。没有?表示贪婪模式。比如a.*b,它将会匹配最长的以a开始,以b结束的字符串。如果用它来搜索aabab的话,它会匹配整个字符串aabab。这被称为贪婪匹配。
又比如模式src=`.*`, 它将会匹配最长的以 src=` 开始,以`结束的最长的字符串。用它来搜索 <img src=``test.jpg` width=`60px` height=`80px`/> 时,将会返回 src=``test.jpg` width=`60px` height=`80px`

2. .*?

?跟在*或者+后边用时,表示懒惰模式。也称非贪婪模式。就是匹配尽可能少的字符。就意味着匹配任意数量的重复,但是在能使整个匹配成功的前提下使用最少的重复。
a.*?b匹配最短的,以a开始,以b结束的字符串。如果把它应用于aabab的话,它会匹配aab(第一到第三个字符)和ab(第四到第五个字符)。
又比如模式 src=`.*?`,它将会匹配 src=` 开始,以 ` 结束的尽可能短的字符串。且开始和结束中间可以没有字符,因为*表示零到多个。用它来搜索 <img src=``test.jpg` width=`60px` height=`80px`/> 时,将会返回 src=``

3. .+?

同上,?跟在*或者+后边用时,表示懒惰模式。也称非贪婪模式。就意味着匹配任意数量的重复,但是在能使整个匹配成功的前提下使用最少的重复。
a.+?b匹配最短的,以a开始,以b结束的字符串,但a和b中间至少要有一个字符。如果把它应用于ababccaab的话,它会匹配abab(第一到第四个字符)和aab(第七到第九个字符)。注意此时匹配结果不是ab,abaab。因为a和b中间至少要有一个字符。
又比如模式 src=`.+?`,它将会匹配 src=` 开始,以 ` 结束的尽可能短的字符串。且开始和结束中间必须有字符,因为+表示1到多个。用它来搜索 <img src=``test.jpg` width=`60px` height=`80px`/> 时,将会返回 src=``test.jpg`。注意与.*?时的区别,此时不会匹配src=``,因为src=`` 之间至少有一个字符。

4. 示例代码

import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.junit.jupiter.api.Test;

public class TestRegx {

 @Test
 public void testRegx(){

 String str = "<img src=``test.jpg` width=`60px` height=`80px`/>";

 String pattern1 = "src=`.*`";
 String pattern2 = "src=`.*?`";
 String pattern3 = "src=`.+?`";

 Pattern p1 = Pattern.compile(pattern1);
 Pattern p2 = Pattern.compile(pattern2);
 Pattern p3 = Pattern.compile(pattern3);

 Matcher m1 = p1.matcher(str);
 Matcher m2 = p2.matcher(str);
 Matcher m3 = p3.matcher(str);

 System.out.println("根据pattern1匹配的结果:");
 if (m1.find()) {
 for(int i=0; i<=m1.groupCount(); i++){
 System.out.println(m1.group(i));
 }
 }

 System.out.println("根据pattern2匹配的结果:");
 if (m2.find()) {
 for(int i=0; i<=m2.groupCount(); i++){
 System.out.println(m2.group(i));
 }
 }

 System.out.println("根据pattern3匹配的结果:");
 if (m3.find()) {
 for(int i=0; i<=m3.groupCount(); i++){
 System.out.println(m3.group(i));
 }
 }

 String[] str1 = p1.split(str);
 String[] str2 = p2.split(str);
 String[] str3 = p3.split(str);

 System.out.println("根据pattern1切分的结果");
 for (int i=0; i< str1.length; i++) {
 System.out.println(str1[i]);
 }

 System.out.println("根据pattern2切分的结果");
 for (int i=0; i< str2.length; i++) {
 System.out.println(str2[i]);
 }

 System.out.println("根据pattern3切分的结果");
 for (int i=0; i< str3.length; i++) {
 System.out.println(str3[i]);
 }
 }
}

5. 示例结果

在这里插入图片描述

更多精彩内容其他人还在看

正则表达式匹配 非XXX的行

问题:如何匹配"非:.+123.123.123.10.+ " 行
收藏 0 赞 0 分享

正则表达式不包含属性

一个标签里不包含某个属性 的 正则表达式的写法
收藏 0 赞 0 分享

ASP正则函数替换分页后的参数

在分页系统里面用到的把page后面得东西都给丢掉
收藏 0 赞 0 分享

asp match正则函数使用Matchs实例

asp matchs函数提供了对正则表达式匹配的只读属性的访问。一直都用这个函数,没想到本站竟然没有这类文章,汗一个,最近我会多加一些这样的文章
收藏 0 赞 0 分享

asp 图片正则 替换,替换前检查图片是不是本地地址的方法

这个图片正则先检查图片的地址,不是本地的则用本地的asp突破盗链,方便使用,注意是答chinaz的朋友问的一个问题
收藏 0 赞 0 分享

java正则表达式彻底研究

从J2SE1.4起Java增加了对正则表达式的支持就是java.util.regex包
收藏 0 赞 0 分享

正则表达式口诀 正则表达式学习工具

正则表达式口诀 + 常用的正则表达式 + 正则表达式学习工具+正则处理工具 正则是每个程序员绕不开的堡垒,只有把它攻下来。我觉得正则之所以难,第一难是需要记忆,第二难是要求具备抽象逻辑思维。
收藏 0 赞 0 分享

比较实用的正则表达式学习笔记

最近在学习正则,一些比较有用的东西怕忘记,记下来,比较乱,想一条记录一条
收藏 0 赞 0 分享

asp只采集网站可见文本的正则

它可以过虑Js 可以过滤 CSS 过滤HTML标识,只采集页面的可见文本。
收藏 0 赞 0 分享

asp.net常用正则表达式

比较常用的多种语言支持的正则整理收集
收藏 0 赞 0 分享
查看更多