正则表达式
符号
注意:任何预定义字符没有加上数量词之前只能匹配一个字符。
"12".matches("\\d\\d");//这里匹配了两个
注意:这里只匹配一个
案例
匹配(matches)
匹配QQ号
String qq = "123456";
String reg = "[1-9][0-9]{4,14}";
boolean b = qq.matches(req);
匹配手机号码
String reg = "1[35]\\d{9}";
匹配邮箱
String reg = "[a-zA-Z1-9]\\w{5,17}@[a-zA-Z0-9]{2,}(\\.(com|cn|net)){1,2 }"
切割(split)
切割空格
str = "-1 99 4 23";
String[] arr = str.split(" +");
根据重叠词切割(正则表达式内容复用:分组)
\1:代表第一组内容,组号是从1开始
String str = "大家家家家家好好好啊";
str.split("(.)\\1+");
替换(replaceAll)
String reg = "1[34578]\\d{9}"
str.replaceAll(reg, "*****");
正则的外部引用分组内容,使用$符号
String str = "大大大家家家好好好";
str.replaceAll("(.)\\1", "$1");
查找
使用的对象:1. Pattern 对象 2. Matcher对象
指定字符串的正则表达式必须首先被编译为此类的实例。然后,可将得到的正则对象匹配任意的字符串用于创建Matcher对象,执行匹配所涉及的所有状态都驻留在匹配器中,所以多个匹配器可以共享同一模式。
典型的调用顺序:
Pattern p = Pattern.compile("正则");
Matcher m = p.matcher("aaaaab");
boolean b = m.matches();
匹配器常用的方法
find()//如果能查到符合规则的字符串,则返回true,否则返回false
group()//获取符合规则的子串
注意:使用group方法的时候一定要先调用find方法匹配器去查找符合规则的字符串,否则报错
//找出三个字母的
String content = "da jia hao a ";
String reg = "\\b[a-zA-Z]{3}\\b";
Pattern p = pattern.compile(reg);
Matcher m = p.matcher(content);
m.find();
m.group();
上面用到了单词边界匹配器 :\b 单词边界匹配器只是代表了单词的开始和结束部分,不匹配任何的字符
“Hello World”.matches(“hello\b world”); //true