深入淺析正則表達式中的\B和\b
對于正則表達式的中\(zhòng)B和\b 有些地方會出現(xiàn)弄不懂的情況
或許你看了下面這篇博客 你就能夠?qū)B和\b認識加深了
根據(jù)查看API可以知道 \B和\b都是邊界匹配符
先說說\b這個單詞邊界吧!竟然想了解 首先必須清楚什么叫單詞邊界!我們可以以\b為分割來探究一下
單詞邊界
import java.util.regex.Matcher; import java.util.regex.Pattern; public class matcher1 { public static void main(String[] args) { String str="(中文問號?123???英文)問號?我是華麗[的制表符\t]我是華麗{的空格符 我是華麗}的換行符\n"; String rex="\\b"; Pattern pattern=Pattern.compile(rex); Matcher matcher=pattern.matcher(str); String [] result=pattern.split(str); for(String string:result){ System.out.println("分割的字符串:"+"["+string+"]"); } } }
運行結(jié)果
分割的字符串:[(]
分割的字符串:[中文問號]
分割的字符串:[?]
分割的字符串:[123]
分割的字符串:[???]
分割的字符串:[英文]
分割的字符串:[)]
分割的字符串:[問號]
分割的字符串:[?]
分割的字符串:[我是華麗]
分割的字符串:[[]
分割的字符串:[的制表符]
分割的字符串:[ ]]
分割的字符串:[我是華麗]
分割的字符串:[{]
分割的字符串:[的空格符]
分割的字符串:[ ]
分割的字符串:[我是華麗]
分割的字符串:[}]
分割的字符串:[的換行符]
分割的字符串:[
]
從這些分割的字符串中我們可以知道單詞邊界就是單詞和符號之間的邊界
這里的單詞可以是中文字符,英文字符,數(shù)字;符號可以是中文符號,英文符號,空格,制表符,換行
下面我們看一個例子
import java.util.regex.Matcher; import java.util.regex.Pattern; public class matcher1 { public static void main(String[] args) { String str=" 2 "; String rex="\\b2\\b"; Pattern pattern=Pattern.compile(rex); Matcher matcher=pattern.matcher(str); if(matcher.matches()){ System.out.println("匹配成功"); }else{ System.out.println("匹配不成功"); } } }
在沒有看上面分割的例子前估計很多人包括我都會認為這運行的結(jié)果是匹配成功
經(jīng)過分割的例子后就知道了 空格并不是邊界 空格與數(shù)字2之間的那個才叫邊界 所以運行結(jié)果不言而喻 肯定是匹配不成功
當如果你這樣寫就運行出來就是匹配成功
import java.util.regex.Matcher; import java.util.regex.Pattern; public class matcher1 { public static void main(String[] args) { String str="2"; String rex="\\b2\\b"; Pattern pattern=Pattern.compile(rex); Matcher matcher=pattern.matcher(str); if(matcher.matches()){ System.out.println("匹配成功"); }else{ System.out.println("匹配不成功"); } } }
\b的用法
一般來說\b不用來判斷當前字符串是否符合某種規(guī)則
一般我們都用\b來進行獲取
import java.util.regex.Matcher; import java.util.regex.Pattern; public class matcher1 { public static void main(String[] args) { String str=",,,,呵呵,,,,"; String rex="\\b呵呵\\b"; Pattern pattern=Pattern.compile(rex); Matcher matcher=pattern.matcher(str); if(matcher.find()){ System.out.println(matcher.group()); } } }
運行結(jié)果
呵呵1
\B的用法
了解了\b的用法 我們再來說說\B \B是非單詞邊界
也就說\B=[^\b]//符號^是非的意思1
\b是單詞與符號的邊界 那非單詞與符號的邊界的其它都是\B
所以我們的猜想\B是符號與符號,單詞與單詞的邊界
當然猜想需要認證!下面我們寫一個例子來證明一個!
import java.util.regex.Matcher; import java.util.regex.Pattern; public class matcher1 { public static void main(String[] args) { String str="123456我是JAVA{,、;‘a(chǎn)sd"; String rex="\\B"; Pattern pattern=Pattern.compile(rex); Matcher matcher=pattern.matcher(str); String [] result=pattern.split(str); for(String string:result){ System.out.println("分割的字符串:"+string); } } }
運行結(jié)果
分割的字符串:1
分割的字符串:2
分割的字符串:3
分割的字符串:4
分割的字符串:5
分割的字符串:6
分割的字符串:我
分割的字符串:是
分割的字符串:J
分割的字符串:A
分割的字符串:V
分割的字符串:A{ //單詞與符號之間的邊界不算\B的邊界
分割的字符串:,
分割的字符串:、
分割的字符串:;
分割的字符串:‘a(chǎn)
分割的字符串:s
分割的字符串:d
事實證明\B作為非單詞邊界 確實是單詞與單詞,符號與符號之間的邊界
\B一般也是用來獲取字符串的
import java.util.regex.Matcher; import java.util.regex.Pattern; public class matcher1 { public static void main(String[] args) { String str=",,,,,和呵呵,,,,,"; String rex="\\B呵\\B"; Pattern pattern=Pattern.compile(rex); Matcher matcher=pattern.matcher(str); if(matcher.find()){ System.out.println(matcher.group()); } } }
因為字符與字符之間的邊界
所以運行的結(jié)果是
呵
補充:
總結(jié)
以上所述是小編給大家介紹的正則表達式中的\B和\b ,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
正則表達式實現(xiàn)將MM/DD/YYYY格式的日期轉(zhuǎn)換為YYYY-MM-DD格式
這篇文章主要介紹了正則表達式實現(xiàn)將MM/DD/YYYY格式的日期轉(zhuǎn)換為YYYY-MM-DD格式的方法,是一個比較簡單實用的正則替換應(yīng)用,對于怎能則表達式的學(xué)習(xí)具有一定的參考借鑒價值,需要的朋友可以參考下2014-12-12