正则表达式知识详解之贪婪模式和非贪婪模式 (java版示例)

前端之家收集整理的这篇文章主要介绍了正则表达式知识详解之贪婪模式和非贪婪模式 (java版示例)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
@H_403_0@正则表达式知识详解系列,通过代码示例来说明正则表达式知识,建议自己按照例子手打一遍。

@H_403_0@本示例的源代码下载地址:http://download.csdn.net/detail/gnail_oug/9504094

@H_403_0@

@H_403_0@

@H_403_0@示例:

@H_403_0@1、贪婪模式提取html标签里的内容

@H_403_0@2、非贪婪模式提前html标签里的内容

//提取td元素里的内容
String str="<table><tr><td>hello world</td><td>hello regex</td></tr></table>";

//贪婪模式  * + {n,} 默认情况是贪婪模式匹配
System.out.println("====贪婪模式=====");
//编译正则表达式到模式对象
Pattern p=Pattern.compile("<td>.*</td>");
//得到匹配器
Matcher m=p.matcher(str);
//通过find方法查找匹配,找到就返回true,否则返回false
while(m.find()){
	//通过group方法获取前面find查找到的子字符串,start、end方法获取子字符串开始和结束位置
	System.out.println(m.group()+"   位置:["+m.start()+","+m.end()+"]");
}

//非贪婪模式,?跟在 * + {n,} 等的后面时,表示非贪婪模式,注意和子表达式后面的?区分开,子表达式后的?表示匹配0次或1次
System.out.println("====非贪婪模式=====");
p=Pattern.compile("<td>.*?</td>");
m=p.matcher(str);
while(m.find()){
	System.out.println(m.group()+"   位置:["+m.start()+","+m.end()+"]");
}

@H_403_0@运行结果:

====贪婪模式=====
<td>hello world</td><td>hello regex</td>   位置:[11,51]
====非贪婪模式=====
<td>hello world</td>   位置:[11,31]
<td>hello regex</td>   位置:[31,51]

猜你在找的正则表达式相关文章