特色:用于一些特定的符号表示代码的操做,这样就简化了长篇的程序代码程序员
弊端:符号定义越多,正则越长,阅读性越差正则表达式
1 String: boolean string.matches(String regex) 2 Pattern + Matcher: Pattern pattern.compile(String regex) Matcher pattern.matcher(String regex) boolean matcher.matches() 3 Pattern boolean b = Pattern.matches(String regex, String string)
1 String:String[] split(String regex) 2 String:String[] split(String regex, int limit) > 为了让规则的结果被重用,可让规则封装成一个组,用()完成。组的出现都有编号: 从1开始想要使用已有的组能够经过格式:\ + 组序号 Eg:以叠词做为分隔符号,切隔字符串:(.)\1+ Eg: (X(Y(Z)))(M) 组号:1 2 3 4
1 String:String replaceAll(String regex, String replacement):regex-\n 2 String:String replaceFirst(String regex, String replacement):replacement-$n 3 Pattern + Matcher: Pattern pattern.compile(String regex) Matcher pattern.matcher(String regex) ------------------------------------- String matcher.quoteReplacement(String s) String matcher.replaceAll(String replacement) String replaceFirst(String replacement)
将正则表达式封装成对象;让正则表达式和要操做的字符串相关联;关联后,获取正则匹配引擎;经过引擎对符合规则的子串进行操做,如:取出 1 //step1:将规则封装成对象 Pattern pattern = Pattern.compile(regex); //step2:让正则对象和要提取的字符串相关联,获取匹配(器)引擎对象 Matcher matcher = pattern.matcher(string); while(matcher.find()) {//不断地利用正则引擎查找符合正则表达式的对象,找到:true;没有找到:false System.out.println("start:" + matcher.start() + " word:" + matcher.group() + " end:" + matcher.end());//返回当前查找到的一个子串,并返回其单词的开始start()与结束区间end() }
[黑马程序员_毕向东_Java基础视频教程第25天](http://www.huahuionline.com/MainCtrl?page=ShowLessonDetailPage&lesson_id=56c1838945ceb61ab5246f3d&cNo=1)