好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 深入淺析正則表達(dá)式中的\B和\b

深入淺析正則表達(dá)式中的\B和\b

熱門標(biāo)簽:甘肅醫(yī)療外呼系統(tǒng)排名 地圖標(biāo)注教學(xué)點(diǎn) 貴港公司如何申請400電話 ai電話機(jī)器人搭建 梅縣地圖標(biāo)注 外呼系統(tǒng)無呼出路由是什么原因 呼叫系統(tǒng)外呼只能兩次 400電話辦理電話辦理 西藏智能外呼系統(tǒng)代理商

對于正則表達(dá)式的中\(zhòng)B和\b 有些地方會出現(xiàn)弄不懂的情況

或許你看了下面這篇博客 你就能夠?qū)B和\b認(rèn)識加深了

根據(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+"]");
 }
 }
}

運(yùn)行結(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("匹配不成功");
 }
 }
}

在沒有看上面分割的例子前估計(jì)很多人包括我都會認(rèn)為這運(yùn)行的結(jié)果是匹配成功

經(jīng)過分割的例子后就知道了 空格并不是邊界 空格與數(shù)字2之間的那個才叫邊界  所以運(yùn)行結(jié)果不言而喻 肯定是匹配不成功

當(dāng)如果你這樣寫就運(yùn)行出來就是匹配成功

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不用來判斷當(dāng)前字符串是否符合某種規(guī)則

一般我們都用\b來進(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的用法 我們再來說說\B \B是非單詞邊界

也就說\B=[^\b]//符號^是非的意思1

\b是單詞與符號的邊界 那非單詞與符號的邊界的其它都是\B

所以我們的猜想\B是符號與符號,單詞與單詞的邊界

當(dāng)然猜想需要認(rèn)證!下面我們寫一個例子來證明一個!

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{      //單詞與符號之間的邊界不算\B的邊界
分割的字符串:,
分割的字符串:、
分割的字符串:;
分割的字符串:‘a(chǎn)
分割的字符串:s
分割的字符串:d

事實(shí)證明\B作為非單詞邊界 確實(shí)是單詞與單詞,符號與符號之間的邊界

\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());
 }

 }
}

因?yàn)樽址c字符之間的邊界

所以運(yùn)行的結(jié)果是

補(bǔ)充:

字符串:abcsdsadas abc asdsadasdabcasdsa

使用\sabc\s和\babc\b都能匹配中間的abc,這種方法不是重復(fù)了么,/s是匹配空格回車等得,/b網(wǎng)上教程說得不清楚什么字符邊界什么意思。

不一樣

\babc\b匹配的是"abc"
\sabc\s匹配的不是"abc", 前后還帶空格" abc "
\b只是匹配字符串開頭結(jié)尾及空格回車等的位置, 不會匹配空格符本身

例如"abc sdsadasabcasdsadasdabcasdsa",

\sabc\s不能匹配,\babc\b可以匹配到"abc" 

\b代表字與字中間那個看不見的東西,如

here is a word

那么,這句中有好幾個\b, 每個單詞的前后都有一個\b.

所以你用 \bhere\b 可以匹配上面這個here,但如果here 不是一個單詞,而是一個單詞的一部分,如 adheread, 這樣的話,用here 可以匹配,用\bhere\b就不能區(qū)配了,因?yàn)閍d后面沒有\(zhòng)b. 所以 adhere 中的here 不會被匹配。

總結(jié): \b 就是用在你匹配整個單詞的時候。 如果不是整個單詞就不匹配。 你想匹配 I 的話,你知道,很多單詞里都有I的,但我只想匹配I,就是“我”,這個時候用 \bI\b

\B就是反過來,代表非字間。 類似\d代表數(shù)字, \D代表非數(shù)字。

總結(jié)

以上所述是小編給大家介紹的正則表達(dá)式中的\B和\b ,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

您可能感興趣的文章:
  • python 正則表達(dá)式 re.sub & re.subn
  • JS正則表達(dá)式修飾符global(/g)用法分析
  • iOS App開發(fā)中Objective-C使用正則表達(dá)式進(jìn)行匹配的方法
  • 詳解Ruby中正則表達(dá)式對字符串的匹配和替換操作
  • Python的爬蟲包Beautiful Soup中用正則表達(dá)式來搜索
  • MongoDB正則表達(dá)式及應(yīng)用

標(biāo)簽:常州 湖州 大興安嶺 海口 泰安 涼山 本溪 哈密

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《深入淺析正則表達(dá)式中的\B和\b》,本文關(guān)鍵詞  深入,淺析,正則,表達(dá)式,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《深入淺析正則表達(dá)式中的\B和\b》相關(guān)的同類信息!
  • 本頁收集關(guān)于深入淺析正則表達(dá)式中的\B和\b的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 滚床单无遮挡| 喀喇沁旗| 91久久人澡人人添人人爽乱抬| 韩国伦理电影在线观看午夜电影网| 娇妻被黑人调教| 国产在线拍揄拍自揄拍无码资源网| 变性后被老板占为私有财产犯法吗| 成年女人免费看一级人体片| 极品丝袜系李雨扬列txt| 女学生喷浆???视频麻豆| 久久久久久精品免费啪啪国卢| 国产欧美一区二区三| avtt手机天堂网一本热系列| 成人性生交大片免费看中国 | 国无码精品一区二区三区在线蜜臀 | 第159章别墅贵妇吞巨大小说| 91久久国产露脸精品国产护士 | **aaaaa毛片免费| 国产91在线看| 强H被cao哭高H| 公交车强摁做开腿呻吟| 欲成欢(1-6部全)| 成人免费视频Ⅹvideos| 日本人视频18亅丨zz| 日本性色视频| av天天看| 娇小老少配xxxxx性视频| 男女猛烈啪啪无遮挡激烈| 日产精品一线二线三线茄子 | 在线免费观看韩国a视频| 翟凌囗交全套高清视频在线观看| 九九视频这里只有精品| 奶大灬舒服灬一进一出三区 | wwwav视频| 久久久无码精品秘?人口| 四川农村少妇A片免费看| 体育男生吃武警大雕| 久久国产亚洲偷自| 精品一区二区三区3d动漫| 一本伊在人香蕉线观新在线| 蜜桃成熟时33d在线|