對(duì)于正則表達(dá)式的中\(zhòng)B和\b 有些地方會(huì)出現(xiàn)弄不懂的情況
或許你看了下面這篇博客 你就能夠?qū)B和\b認(rèn)識(shí)加深了
根據(jù)查看API可以知道 \B和\b都是邊界匹配符
先說(shuō)說(shuō)\b這個(gè)單詞邊界吧!竟然想了解 首先必須清楚什么叫單詞邊界!我們可以以\b為分割來(lái)探究一下
單詞邊界
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class matcher1 {
public static void main(String[] args) {
String str="(中文問(wèn)號(hào)?123???英文)問(wèn)號(hào)?我是華麗[的制表符\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+"]");
}
}
}
運(yùn)行結(jié)果
分割的字符串:[(]
分割的字符串:[中文問(wèn)號(hào)]
分割的字符串:[?]
分割的字符串:[123]
分割的字符串:[???]
分割的字符串:[英文]
分割的字符串:[)]
分割的字符串:[問(wèn)號(hào)]
分割的字符串:[?]
分割的字符串:[我是華麗]
分割的字符串:[[]
分割的字符串:[的制表符]
分割的字符串:[ ]]
分割的字符串:[我是華麗]
分割的字符串:[{]
分割的字符串:[的空格符]
分割的字符串:[ ]
分割的字符串:[我是華麗]
分割的字符串:[}]
分割的字符串:[的換行符]
分割的字符串:[
]
從這些分割的字符串中我們可以知道單詞邊界就是單詞和符號(hào)之間的邊界
這里的單詞可以是中文字符,英文字符,數(shù)字;符號(hào)可以是中文符號(hào),英文符號(hào),空格,制表符,換行
下面我們看一個(gè)例子
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("匹配不成功");
}
}
}
在沒(méi)有看上面分割的例子前估計(jì)很多人包括我都會(huì)認(rèn)為這運(yùn)行的結(jié)果是匹配成功
經(jīng)過(guò)分割的例子后就知道了 空格并不是邊界 空格與數(shù)字2之間的那個(gè)才叫邊界 所以運(yùn)行結(jié)果不言而喻 肯定是匹配不成功
當(dāng)如果你這樣寫(xiě)就運(yùn)行出來(lái)就是匹配成功
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的用法
一般來(lái)說(shuō)\b不用來(lái)判斷當(dāng)前字符串是否符合某種規(guī)則
一般我們都用\b來(lái)進(jìn)行獲取
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());
}
}
}
運(yùn)行結(jié)果
呵呵1
\B的用法
了解了\b的用法 我們?cè)賮?lái)說(shuō)說(shuō)\B \B是非單詞邊界
也就說(shuō)\B=[^\b]//符號(hào)^是非的意思1
\b是單詞與符號(hào)的邊界 那非單詞與符號(hào)的邊界的其它都是\B
所以我們的猜想\B是符號(hào)與符號(hào),單詞與單詞的邊界
當(dāng)然猜想需要認(rèn)證!下面我們寫(xiě)一個(gè)例子來(lái)證明一個(gè)!
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);
}
}
}
運(yùn)行結(jié)果
分割的字符串:1
分割的字符串:2
分割的字符串:3
分割的字符串:4
分割的字符串:5
分割的字符串:6
分割的字符串:我
分割的字符串:是
分割的字符串:J
分割的字符串:A
分割的字符串:V
分割的字符串:A{ //單詞與符號(hào)之間的邊界不算\B的邊界
分割的字符串:,
分割的字符串:、
分割的字符串:;
分割的字符串:‘a(chǎn)
分割的字符串:s
分割的字符串:d
事實(shí)證明\B作為非單詞邊界 確實(shí)是單詞與單詞,符號(hào)與符號(hào)之間的邊界
\B一般也是用來(lái)獲取字符串的
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());
}
}
}
因?yàn)樽址c字符之間的邊界
所以運(yùn)行的結(jié)果是
呵
補(bǔ)充:
正則表達(dá)式中\(zhòng)b和\s有什么區(qū)別
字符串:abcsdsadas abc asdsadasdabcasdsa
使用\sabc\s和\babc\b都能匹配中間的abc,這種方法不是重復(fù)了么,/s是匹配空格回車(chē)等得,/b網(wǎng)上教程說(shuō)得不清楚什么字符邊界什么意思。
不一樣
\babc\b匹配的是"abc"
\sabc\s匹配的不是"abc", 前后還帶空格" abc "
\b只是匹配字符串開(kāi)頭結(jié)尾及空格回車(chē)等的位置, 不會(huì)匹配空格符本身
例如"abc sdsadasabcasdsadasdabcasdsa",
\sabc\s不能匹配,\babc\b可以匹配到"abc"
\b代表字與字中間那個(gè)看不見(jiàn)的東西,如
here is a word
那么,這句中有好幾個(gè)\b, 每個(gè)單詞的前后都有一個(gè)\b.
所以你用 \bhere\b 可以匹配上面這個(gè)here,但如果here 不是一個(gè)單詞,而是一個(gè)單詞的一部分,如 adheread, 這樣的話,用here 可以匹配,用\bhere\b就不能區(qū)配了,因?yàn)閍d后面沒(méi)有\(zhòng)b. 所以 adhere 中的here 不會(huì)被匹配。
總結(jié): \b 就是用在你匹配整個(gè)單詞的時(shí)候。 如果不是整個(gè)單詞就不匹配。 你想匹配 I 的話,你知道,很多單詞里都有I的,但我只想匹配I,就是“我”,這個(gè)時(shí)候用 \bI\b
\B就是反過(guò)來(lái),代表非字間。 類(lèi)似\d代表數(shù)字, \D代表非數(shù)字。
總結(jié)
以上所述是小編給大家介紹的正則表達(dá)式中的\B和\b ,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
您可能感興趣的文章:- python 正則表達(dá)式 re.sub & re.subn
- JS正則表達(dá)式修飾符global(/g)用法分析
- iOS App開(kāi)發(fā)中Objective-C使用正則表達(dá)式進(jìn)行匹配的方法
- 詳解Ruby中正則表達(dá)式對(duì)字符串的匹配和替換操作
- Python的爬蟲(chóng)包Beautiful Soup中用正則表達(dá)式來(lái)搜索
- MongoDB正則表達(dá)式及應(yīng)用