您的位置:首页 > 编程语言 > Java开发

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).


四.注意

只有当匹配操作成功(成功就是当matches(),lookingAt(),find()其中任意一个方法返回true时),才可以使用start(),end(),group()三个方法,否则会抛出java.lang.IllegalStateException.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息