1.定义
正则表达式定义了字符串的模式,正则表达式是一一对应匹配。正则表达式可以用来搜索、编辑或处理文本。正则表达式存在于所有的语言,但是在每种语言中略有差别。
2.API
正则表达式主要包含三个类
Pattern 类:pattern 对象是一个正则表达式的编译表示。Pattern 类没有公共构造方法。要创建一个 Pattern 对象,你必须首先调用其公共静态编译方法,它返回一个 Pattern 对象。该方法接受一个正则表达式作为它的第一个参数。
Matcher 类:Matcher 对象是对输入字符串进行解释和匹配操作的引擎。与Pattern 类一样,Matcher 也没有公共构造方法。你需要调用 Pattern 对象的 matcher 方法来获得一个 Matcher 对象。
PatternSyntaxException:PatternSyntaxException 是一个非强制异常类,它表示一个正则表达式模式中的语法错误。
3.实例
在其他语言中,\ 表示:我想要在正则表达式中插入一个普通的(字面上的)反斜杠,请不要给它任何特殊的意义。
在 Java 中,\ 表示:我要插入一个正则表达式的反斜线,所以其后的字符具有特殊的意义。
- \s表示空白字符;\s+多个空白字符,+表示一个或多个字符
public static boolean isText(String str) {
Pattern p = Pattern.compile("this\\sis\\stext");
//Pattern p = Pattern.compile("this\\s+is\\s+text");
Matcher m = p.matcher(str);
return m.matches();
}
- "."表示任何一个字符
public static boolean isNumChar(String str) {
Pattern p = Pattern.compile("lzhangsan.test");
Matcher m = p.matcher(str);
return m.matches();
}
- 捕获组
()()():这个则表达式可以分为几个捕获组,可以按组号获取字符
下面的\d表示0-9任意数字,\.表示转义符加".“就是表示”.",其中group(0)表示整个表达式
public static boolean isNum(String str) {
Pattern p = Pattern.compile("(\\d\\.)(\\d)(\\d)");
Matcher matcher = p.matcher(str);
if (matcher.find()) {
System.out.println("有匹配");
System.out.println(matcher.group(0));
System.out.println(matcher.group(1));
System.out.println(matcher.group(2));
System.out.println(matcher.group(3));
} else {
System.out.println("没有匹配");
}
return matcher.matches();
}
- “+”:表示一次或多次匹配字符;“*”:表示0次或多次表示字符;{n},{n,},{n,m}:表示匹配次数限制
public static boolean isTest(String str){
// Pattern p = Pattern.compile("(I love u)*"); //匹配0次或多次“I love u”
// Pattern p = Pattern.compile("I love u*"); //匹配I +love+ 加0次或多次u
// Pattern p = Pattern.compile("I love u+"); //匹配I+love +加1次或多次u
// Pattern p = Pattern.compile("I (love){2} u"); //匹配I +(2次)love + u
// Pattern p = Pattern.compile("I (love){1,} u");//匹配I +(至少1次)love + u
Pattern p = Pattern.compile("I (love){1,3} u");//匹配I +(至少1次最多3次)love + u
Matcher matcher = p.matcher(str);
return matcher.matches();
}
- 用正则表达式匹配1-120的数字
"|"表示或,[0,1]表示0或者1,[1-9]表示1到9
public static boolean isAge(String str){
//Pattern p = Pattern.compile("120|(1[0-1])(\\d)|[1-9]\\d|\\d");
Pattern p = Pattern.compile("(120)|((1[0-1])|([1-9]))?\\d");
Matcher matcher = p.matcher(str);
return matcher.matches();
}