java正则表达式
语法规则:
- ^ 表示正则匹配以…开头
- $ 表示正则匹配以…结尾
- * 0次或者多次
- + 1次或者多次
- ? 0次或者1次
- [xyz] 匹配xyz中任意一个字符
- [^xyz] 匹配除了x或者y或者z的任意一个字符
- [a-zA-Z0-9] 匹配指定范围内的任意一个字符
- {m} 重复m次
- {m,} 表示最少重复m次,最多无上限
- {m,n} 表示最少重复m次,最多重复n次(n包括)
- | 表示多个表达式或
- \w 表示匹配任意字母和数字 \W相反
- \d 表示匹配数字 \D相反
- \s 表示匹配空白 \S相反
- \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());
}