正则表达式第三篇(Java中使用正则表达式)

看一下最基础的用法,如下:

//matches find lookingAt
		Pattern p = Pattern.compile("\\d{3,5}"); // 数字出现3-5次
		String s = "123-34345-234-00"; 
		Matcher m = p.matcher(s); 
		//false matches:是匹配整个字符串。一次吃5个字符去匹配 ??
		System.out.println("m.matches()="+m.matches());
		System.out.println("2----------------------------------------");
		
		m.reset(); // 字符串扫描归位:下面的从头开始扫描 
		System.out.println("m.find()="+m.find()); // 找一个匹配的字串而不是整个字符串
		System.out.println(m.start() + "-" + m.end());
		System.out.println("3----------------------------------------");

		
		System.out.println("4----------------------------------------");
		System.out.println(m.lookingAt()); /*每次从头找匹配的子串*/
		System.out.println(m.lookingAt());
		System.out.println(m.lookingAt());
		System.out.println(m.lookingAt());


 在使用Pattern.compile函数时,可以加入控制正则表达式的匹配行为的参数,Pattern Pattern.compile(String regex, int flag) flag的取值范围如下: 


     Pattern.CANON_EQ  当且仅当两个字符的"正规分解(canonical decomposition)"都完全相同的情况下,才认定匹配。比如用了这个标志之后,表达式"a\u030A"会匹配"?"。默认情况下,不考虑"规范相等性(canonical equivalence)"。 

     Pattern.CASE_INSENSITIVE(?i)  默认情况下,大小写不明感的匹配只适用于US-ASCII字符集。这个标志能让表达式忽略大小写进行匹配。要想对Unicode字符进行大小不明感的匹配,只要将UNICODE_CASE与这个标志合起来就行了。 

     Pattern.COMMENTS(?x)  在这种模式下,匹配时会忽略(正则表达式里的)空格字符(译者注:不是指表达式里的"\\s",而是指表达式里的空格,tab,回车之类)。注释从#开始,一直到这行结束。可以通过嵌入式的标志来启用Unix行模式。 

     Pattern.DOTALL(?s)  这种模式下,表达式'.'可以匹配任意字符,包括表示一行的结束符。默认情况下,表达式'.'不匹配行的结束符。 

     Pattern.MULTILINE (?m)  在这种模式下,'^'和'$'分别匹配一行的开始和结束。此外,'^'仍然匹配字符串的开始,'$'也匹配字符串的结束。默认情况下,这两个表达式仅仅匹配字符串的开始和结束。 

      Pattern.UNICODE_CASE (?u)  在这个模式下,如果你还启用了CASE_INSENSITIVE标志,那么它会对Unicode字符进行大小写不明感的匹配。默认情况下,大小写不敏感的匹配只适用于US-ASCII字符集。 

     Pattern.UNIX_LINES(?d)  在这个模式下,只有'\n'才被认作一行的中止,并且与'.','^',以及'$'进行匹配。

public static  void  search1()
	{
		Pattern p = Pattern.compile("java");
		Matcher m = p.matcher("java Java JAVa JaVa IloveJAVA you hateJava afasdfasdf");
		
		while(m.find()) {
			 System.out.println(m.group());
		}
	}
	
	
	public static  void  search2()
	{
		Pattern p = Pattern.compile("java", Pattern.CASE_INSENSITIVE); /* Pattern.CASE_INSENSITIVE:常量规则:忽大小写 */
		Matcher m = p.matcher("java Java JAVa JaVa IloveJAVA you hateJava afasdfasdf");
		
		while(m.find()) {
			 System.out.println(m.group());
		}
	}
	
	public static  void  search3()
	{
		Pattern p = Pattern.compile("java", Pattern.CASE_INSENSITIVE);
		Matcher m = p.matcher("java Java JAVa JaVa IloveJAVA you hateJava afasdfasdf");
		StringBuffer buf = new StringBuffer();
		while(m.find()) {
		  m.appendReplacement(buf, "888"); /*将当前找到的进行替换并且换好后放到buf中去*/
		}
		m.appendTail(buf);
		System.out.println(buf);
	}
	








发布了167 篇原创文章 · 获赞 321 · 访问量 58万+

猜你喜欢

转载自blog.csdn.net/mazhimazh/article/details/38944845
今日推荐