_____正则表达式_____
概述
正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符、及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑。
特点
1. 灵活性、逻辑性和功能性非常的强。2. 可以迅速地用极简单的方式达到字符串的复杂控制。
3. 对于刚接触的人来说,比较晦涩难懂,阅读性较差。
正文
在Java中对正则表达式设立了一个专门的包java.util.regex,包里面只有两个类:Matcher匹配器,Pattern模式。Pattern的主要作用就是将正则字符串规则封装成一个模式对象。
Matcher则是通过模式创建出来的匹配器,主要用于将正则表达式与字符串进行匹配。
典型的调用顺序:
//获取给定正则表达式的模式
Pattern p = Pattern.compile("a*b");
//通过模式创建与指定字符串绑定的匹配器
Matcher m = p.matcher("aaaaab");
//进行匹配
boolean b = m.matches();
//三句语句也可以写出一句
boolean b = Pattern.matches("a*b", "aaaaab");
简单实例:
public class Demo {
public static void main(String[] args) {
//需要被匹配的字符串
String s = "ming tian jiu yao Fang jia le ,da jia。";
//匹配规则,\b为单词边界,[a-z]{4}表示4个小写字母
String regex = "\\b[a-z]{4}\\b";
Pattern p = Pattern.compile(regex);
Matcher m = p.matcher(s);
while(m.find()) {
System.out.println("["+m.start()+","+m.end()+"]:"+m.group());
}
}
}
/*
结果:
[0,4]:ming
[5,9]:tian
*/
String类的正则表达式:
String类中很多方法都是封装了正则表达式操作
匹配:
public static boolean isQQ(String s) {
//[1-9]是范围为1-9的一个数字,\d是数字,{4,10}是数量
String regex = "[1-9]\\d{4,10}";
//此方法内部仍然使用Pattern和Matcher来实现的
return s.matches(regex);
}
分割:
public class Demo {
public static void main(String[] args) {
System.out.println(Arrays.toString(split("it hei ma ")));
}
public static String[] split(String s) {
//匹配一个或者多个空格
String regex = " ++";
return s.split(regex);
}
}
/*
结果:
[it, hei, ma]
*/
替换:
public class Demo {
public static void main(String[] args) {
System.out.println(replace("it hei ma "));
}
public static String replace(String s) {
//匹配一个或者多个空格
String regex = " ++";
//将一个或者多个空格都替换成一个*
return s.replaceAll(regex, "*");
}
}
/*
结果:
it*hei*ma*
*/