Matcher

package baidu.Matcher;

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class TestMatcher {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		String string = "你好啊北京,i love you !";
		int count = 0;
		Pattern pattern = Pattern.compile("[\u4e00-\u9fa5]");
		char[] ch = string.toCharArray();
		
		/**
		 * matches()
		 */
		for (int i = 0; i < ch.length; i++) {
			Matcher matcher = pattern.matcher(string.valueOf(ch[i]));
			if (matcher.matches()) {
				count++;
			}
		}	
		System.out.println("字符中包含的汉子个数为:" + count);
		
		/**
		 * find()
		 */
		for (int i = 0; i < ch.length; i++) {
			//String.valueOf(char[] data) : 将 char 数组 data 转换成字符串 
			Matcher matcher = pattern.matcher(String.valueOf(ch[i]));
			if (matcher.find()) {
				String temp = matcher.group();
				System.out.println("matcher.group()  " + temp);
				count++;
			}	
		}
		System.out.println("字符中包含的汉子个数为:" + count);
		
		/**
		 * lookingAt()
		 */
		for (int i = 0; i < ch.length; i++) {
			Matcher matcher = pattern.matcher(string.valueOf(ch[i]));
			if (matcher.lookingAt()) {
				count++;
			}
		}
		System.out.println("字符中包含的汉子个数为:" + count);
		
		/**
		 * matches整个匹配,只有整个字符序列匹配成功才会返回true.如果第一次匹配成功,则下次。。。
		 * find部分匹配,从当前位置开始匹配,找到一个匹配的子串,将移动下次匹配的位置。
		 * lookingAt部分匹配,总是从第一个位置开始匹配,匹配成功了不再继续匹配,匹配失败了也不再继续匹配。
		 */
		for (int i = 0; i < ch.length; i++) {
			Matcher matcher = pattern.matcher(string.valueOf(ch[i]));
			if (matcher.matches()) {
				System.out.println(matcher.start());
				count++;
			}
		}
		System.out.println("字符中包含的汉子个数为:" + count);
		
		for (int i = 0; i < ch.length; i++) {
			Matcher matcher = pattern.matcher(string.valueOf(ch[i]));
			if (matcher.find()) {
				String temp = matcher.group();
				System.out.println("temp=" + temp);
				System.out.println(matcher.start());
				
				count++;
				matcher.reset();
			}
		}
		System.out.println("字符中包含的汉子个数为:" + count);
	}
}

package baidu.Matcher;

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class TestMatcherTest {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		//定义一个表达式模式,’\‘表示下一个字符是特殊字符,'\d'表示数字既0-9,{3,5}表示重复3到5次
		//总的来看:匹配由3个到5个数字组成的字符串(例如”123“,”2345“等)
		Pattern pattern = Pattern.compile("\\d{3,5}");
		String charSequence = "123-34345-234-00";
		Matcher matcher = pattern.matcher(charSequence);
 
		//虽然匹配失败,但由于charSequence里面的"123"和pattern是匹配的,所以下次的匹配从位置4开始
		print(matcher.matches());
		
		/**
		 * find()
		 */
		//测试匹配位置
		matcher.find();
		print(matcher.start());
 
		//使用reset方法重置匹配位置
		matcher.reset();
 
		//第一次find匹配以及匹配的目标和匹配的起始位置
		print("第一次find匹配以及匹配的目标和匹配的起始位置");
		print(matcher.find());
		print(matcher.group()+" - "+matcher.start());
		//第二次find匹配以及匹配的目标和匹配的起始位置
		print("第二次find匹配以及匹配的目标和匹配的起始位置");
		print(matcher.find());
		print(matcher.group()+" - "+matcher.start());
 
		//第一次lookingAt匹配以及匹配的目标和匹配的起始位置
		print("第一次lookingAt匹配以及匹配的目标和匹配的起始位置");
		print(matcher.lookingAt());
		print(matcher.group()+" - "+matcher.start());
 
		//第二次lookingAt匹配以及匹配的目标和匹配的起始位置
		print("第二次lookingAt匹配以及匹配的目标和匹配的起始位置");
		print(matcher.lookingAt());
		print(matcher.group()+" - "+matcher.start());
		
//		print("第一次matches匹配以及匹配的目标和匹配的起始位置");
//		print(matcher.matches());
//		print(matcher.group()+" - "+matcher.start());
//		
//		/*print("第er次matches匹配以及匹配的目标和匹配的起始位置");
//		print(matcher.matches());
//		print(matcher.group()+" - "+matcher.start());*/
		
	}
	public static void print(Object o){
		System.out.println(o);
	}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值