Java正则表达式详解(Pattern类和Matcher类)
2017-01-17 10:06
791 查看
一.Pattern类
(import java.util.regex.Pattern)通过Pattern.complie(String regex)简单工厂方法创建一个正则表达式(PS:它的构造方法是私有的,不可以直接创建)
Pattern p = Pattern.compile("java*"); p.pattern();// 返回java* ,返回的既是正则字符串.
1.Pattern.split(CharSequence arg0).
用于分隔字符串,并返回一个String[]Pattern p =Pattern.compile("\\d+"); String[] str=p.split("a 1 player 2 or 3 nothing");
2.Pattern.matcher(String regex,CharSequence input)
该方法是个静态方法,用于快速匹配字符串,该方法适合用于只匹配一次,且匹配全部字符串.Pattern.matches("\\d+", "111");// 返回true Pattern.matches("\\d+", "111a");// 返回false,需要匹配到所有字符串才能返回true,这里a不能匹配到
二.Matcher类
(import java.util.regex.Matcher)构造方法也是私有的,不能直接创建,只能通过Pattern.matcher(CharSequence input)方法得到该类的实例
1.Pattern.matcher(CharSequence input)
Pattern p = Pattern.compile("\\d+"); Matcher m = p.matcher("22bb23"); m.pattern();// 返回\d+
2.Matcher.matches()/ Matcher.lookingAt()/ Matcher.find()
// matches():对整个字符串进行匹配,只有整个字符串都匹配了才返回true Pattern pm = Pattern.compile("\\d+"); Matcher mm = pm.matcher("1111a"); mm.matches();// 因为a不能被\d+匹配,返回false Matcher mm2 = pm.matcher("1111"); mm2.matches();// 返回true,因为\d+匹配到了整个字符串 // lookingAt():对前面的字符串进行匹配,只有在最前面匹配到才返回true Pattern pl = Pattern.compile("\\d+"); Matcher ml = pl.matcher("1111a"); ml.lookingAt();// 返回true,因为\d+匹配到了前面的1 Matcher ml2 = pl.matcher("a1111"); ml2.lookingAt();// 返回false,因为\d+不能匹配前面的a // find():对字符串进行匹配,匹配到的字符串可以在任何位置. Pattern pf = Pattern.compile("\\d+"); Matcher mf = pf.matcher("1111a"); mf.find();// 返回true Matcher mf2 = pf.matcher("aaaa"); mf2.find();// 返回false
三 .补充
Mathcer下的三个方法:start() ,end() ,group()start():返回匹配到的子字符串在字符串中的索引位置. end():返回匹配到的子字符串的最后一个字符在字符串中的索引位置. group():返回匹配到的子字符串 . 另外 groupCount()用于返回有多少组,自然也给出了相应的按照组查看的方法,及start(),end(),Group()的重载方法:start(int i),end(int i),group(int i).