java正则表达式

语法规则:

  1. ^ 表示正则匹配以…开头
  2. $ 表示正则匹配以…结尾
  3. * 0次或者多次
  4. + 1次或者多次
  5. ? 0次或者1次
  6. [xyz] 匹配xyz中任意一个字符
  7. [^xyz] 匹配除了x或者y或者z的任意一个字符
  8. [a-zA-Z0-9] 匹配指定范围内的任意一个字符
  9. {m} 重复m次
  10. {m,} 表示最少重复m次,最多无上限
  11. {m,n} 表示最少重复m次,最多重复n次(n包括)
  12. | 表示多个表达式或
  13. \w 表示匹配任意字母和数字 \W相反
  14. \d 表示匹配数字 \D相反
  15. \s 表示匹配空白 \S相反
  16. \b 表示单词界限
System.out.println("HelloWorld99.java".matches
	("^[^0-9][a-zA-Z0-9_\\$]+\\.java$"));

	// 正则表达式API
	// 1.创建正则表达式模板对象
Pattern pattern = Pattern.compile("[A-Za-z]+");
	// 2.创建匹配器对象
Matcher matcher = pattern.matcher("你好,我是Java程序员,从事Java工作已经有10年		时间了,我热爱Java和Python,编程是我快乐!");

	// a.精确匹配
	// System.out.println(matcher.matches());
	/*
	 * b.模糊匹配
	 * 
	 * find() 进行模糊匹配正则,注意:该方法操作的是匹配器的游标,操作不可逆 group() 把匹配到的内容打包字符串 start()
	 * 匹配到内容的起始下标 end() 匹配到内容的结束下标
	*/
int count = 0;
while (matcher.find()) {
	count++;
	System.out.println(matcher.group() + "在目标的" + matcher.start() + 	"~" + matcher.end() + "位置处.");
}
System.out.println("目标数据在内容中重复了:" + count + "次.");
System.out.println("-------------------------------------");
	// 匹配3个字符的单词
	// 注意:使用单词界限来控制
pattern = Pattern.compile("\\b[a-zA-Z]{3}\\b");
matcher = pattern.matcher("Happiness is a way station between too much 	and too little.");
while (matcher.find()) {
	System.out.println(matcher.group());
}