国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > regex > 正文

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

2020-01-20 22:00:17
字體:
供稿:網(wǎng)友

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

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

根據(jù)查看API可以知道 /B和/b都是邊界匹配符

先說說/b這個(gè)單詞邊界吧!竟然想了解 首先必須清楚什么叫單詞邊界!我們可以以/b為分割來探究一下

單詞邊界

import java.util.regex.Matcher;import java.util.regex.Pattern;public class matcher1 { public static void main(String[] args) { String str="(中文問號(hào)?123???英文)問號(hào)?我是華麗[的制表符/t]我是華麗{的空格符 我是華麗}的換行符/n"; String rex="http://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é)果

分割的字符串:[(]
分割的字符串:[中文問號(hào)]
分割的字符串:[?]
分割的字符串:[123]
分割的字符串:[???]
分割的字符串:[英文]
分割的字符串:[)]
分割的字符串:[問號(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="http://b2//b"; Pattern pattern=Pattern.compile(rex); Matcher matcher=pattern.matcher(str); if(matcher.matches()){  System.out.println("匹配成功"); }else{  System.out.println("匹配不成功"); } }}

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

經(jīng)過分割的例子后就知道了 空格并不是邊界 空格與數(shù)字2之間的那個(gè)才叫邊界  所以運(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="http://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="http://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]//符號(hào)^是非的意思1

/b是單詞與符號(hào)的邊界 那非單詞與符號(hào)的邊界的其它都是/B

所以我們的猜想/B是符號(hào)與符號(hào),單詞與單詞的邊界

當(dāng)然猜想需要認(rèn)證!下面我們寫一個(gè)例子來證明一個(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="http://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一般也是用來獲取字符串的

import java.util.regex.Matcher;import java.util.regex.Pattern;public class matcher1 { public static void main(String[] args) { String str=",,,,,和呵呵,,,,,"; String rex="http://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é)尾及空格回車等的位置, 不會(huì)匹配空格符本身

例如"abc sdsadasabcasdsadasdabcasdsa",

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

/b代表字與字中間那個(gè)看不見的東西,如

here is a word

那么,這句中有好幾個(gè)/b, 每個(gè)單詞的前后都有一個(gè)/b.

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

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

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

總結(jié)

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

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 诸城市| 龙泉市| 阜阳市| 雷波县| 含山县| 淄博市| 佛教| 乃东县| 阿克陶县| 兴隆县| 龙游县| 蒙自县| 永泰县| 浦城县| 曲周县| 肥西县| 阜康市| 张掖市| 吐鲁番市| 万全县| 水城县| 南城县| 寿宁县| 鄂尔多斯市| 蓬安县| 岳阳市| 尚义县| 泽州县| 淮北市| 两当县| 龙江县| 那坡县| 黎平县| 左贡县| 元氏县| 澎湖县| 上林县| 军事| 武邑县| 南丹县| 安岳县|