正则表达式
- 引入
需求:
校验一个QQ号码。
1. 首位不能为0;
2. 长度是4~10
3. 全部是数字组成
- 代码
/*
正则表达式:
概念:用于操作字符串的规则,在正则表达式中使用了一些特殊的符号代表了字符串的规则
需求:
校验一个QQ号码。
1. 首位不能为0;
2. 长度是4~10
3. 全部是数字组成
*/
public class Demo5 {
public static void main(String[] args) {
String qq = "1245135";
if(!qq.startsWith("0")){
if(qq.length()>=4 && qq.length()<=11){
try{
Long.parseLong(qq);
System.out.println("恭喜你合法qq");
}catch(Exception e){
System.out.println("非法QQ号,qq号只能为数字");
}
}else{
System.out.println("非法QQ号,qq号长度为4~11");
}
}else{
System.out.println("非法QQ号,qq号不能以0开头");
}
//正则
System.out.println(qq.matches("[1-9]\\d{3,10}") ? "合法QQ" : "非法QQ");
}
}
- 概念
用于操作字符串的规则,在正则表达式中使用了一些特殊的符号代表了字符串的规则
- 规则
- matches(String regex)
预定义字符:
. 任何字符(与运行结束符可能匹配也可能不匹配)
\d 数字:[0-9]
\D 非数字:[^0-9]
\s 空白字符:[\t\n\x0B\f\r]
\S 非空白字符:[^\s]
\w 单词字符:[a-zA-Z_0-9]
\W 非单词字符:[^\w]
- 注意
一个预定义字符只能匹配一个字符,除非预定义字符串配合了数量词使用
- 数量词(Greedy)
X?X, 一次或一次也没有
X*X, 零次或多次
X+X, 一次或多次
X{n} X,恰好n次
X{n,} X 至少n次
X{n,m} X 至少n次,但不能超过m次
System.out.println("?一次或一次也没有:"+ ("12".matches("\\d?")));
System.out.println("* 零次或多次:"+ ("12".matches("\\d*")));
System.out.println("+ 至少一次:"+ ("12".matches("\\d+")));
System.out.println("{n} 恰好n次:"+ ("121".matches("\\d{3}")));
System.out.println("{n,} 至少出现n次:"+ ("121".matches("\\d{3,}")));
System.out.println("{n,m} 至少出现 n~ m次 :"+ ("1212111".matches("\\d{3,6}")));
- 范围词
[abc] a,b,c(简单类)
[^abc] 任何字符,除a,b,c(否定)
[a-zA-Z] a-zA-Z,两头包括在内
System.out.println("abc".matches("[abc]+")); //与数量词配合使用
- 正则对字符串最常见的操作:
- 匹配:matches
- 切割:split()
- 替换:replaceAll()
- 查找:使用匹配器
如果正则表达式需要查找内容需要使用以下两个对象:
Pattern(正则对象)
Matcher(匹配器对象)
指定为字符串的正则表达式必须首先被编译为此类Pattern的实例。然后,Pattern对象可以与任意字符序列匹配 ,匹配字符串之后就可以得到一个 Matcher 对象,
所涉及与字符串匹配的状态都驻留在匹配器中 .
典型的调用顺序是
Pattern p = Pattern.compile("正则");
Matcher m = p.matcher("aaaaab");
boolean b = m.matches();
匹配器常用的方法:
find() 通知匹配器去查找符合该正则的字符串。如果存在符合规则的字符串返回true,否则返回false.
group() 获取符合规则的字符串。
注意: 使用匹配器的方法时候,要先调用find方法才能调用group方法。 否则匹配器没有去查找合适的内容,报错。