特色:用於一些特定的符號表示代碼的操做,這樣就簡化了長篇的程序代碼程序員
弊端:符號定義越多,正則越長,閱讀性越差正則表達式
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)