主頁 > 知識(shí)庫 > 正則表達(dá)式之捕獲組/非捕獲組介紹

正則表達(dá)式之捕獲組/非捕獲組介紹

熱門標(biāo)簽:上海銷售電銷機(jī)器人軟件 惠安地圖標(biāo)注 自己做的電銷機(jī)器人 淄博市張店區(qū)地圖標(biāo)注 遼寧秒客來電話機(jī)器人 哈爾濱公司外呼系統(tǒng)代理 山東外呼系統(tǒng)聯(lián)系方式 地圖標(biāo)注店鋪地圖標(biāo)注酒店 浙江營(yíng)銷外呼系統(tǒng)有哪些
捕獲組
語法:

字符 

描述

示例

(pattern)

匹配pattern并捕獲結(jié)果,自動(dòng)設(shè)置組號(hào)。

 (abc)+d

匹配abcd或者abcabcd

(?name>pattern)

(?'name'pattern)

匹配pattern并捕獲結(jié)果,設(shè)置name為組名。

 

\num

對(duì)捕獲組的反向引用。其中 num 是一個(gè)正整數(shù)。

(\w)(\w)\2\1

匹配abba

\k name >

\k' name '

對(duì)命名捕獲組的反向引用。其中 name 是捕獲組名。

(?group>\w)abc\kgroup>

匹配xabcx

使用小括號(hào)指定一個(gè)子表達(dá)式后,匹配這個(gè)子表達(dá)式的文本(也就是此分組捕獲的內(nèi)容)可以在表達(dá)式或其它程序中作進(jìn)一步的處理。默認(rèn)情況下,每個(gè)捕獲組會(huì)自動(dòng)擁有一個(gè)組號(hào),規(guī)則是:從左向右,以分組的左括號(hào)為標(biāo)志,第一個(gè)出現(xiàn)的分組的組號(hào)為1,第二個(gè)為2,以此類推。
例如:
(\d{4})-(\d{2}-(\d{2}))
1 1 2 3 32
以下是用程序處理捕獲組的示例,對(duì)一個(gè)Url地址進(jìn)行解析,并顯示所有捕獲組。
可以看到按順序設(shè)置的捕獲組號(hào)。
Regex.Match方法
復(fù)制代碼 代碼如下:

using System.Text.RegularExpressions;
namespace Wuhong.Test
{
class Program
{
static void Main(string[] args)
{
//目標(biāo)字符串
string source = "http://reg-test-server:8080/download/file1.html# ";
//正則式
string regex = @"(\w+):\/\/([^/:]+)(:\d+)?([^# :]*)";
Regex regUrl = new Regex(regex);
//匹配正則表達(dá)式
Match m = regUrl.Match(source);
Console.WriteLine(m.Success);
if (m.Success)
{
//捕獲組存放在Match.Groups集合中,索引值從1開始,索引0處為匹配的整個(gè)字符串值
//按“組號(hào) : 捕獲內(nèi)容”的格式顯示
for (int i = 0; i m.Groups.Count; i++)
{
Console.WriteLine(string.Format("{0} : {1}", i, m.Groups[i]));
}
}
Console.ReadLine();
}
}
}

也可以自己指定子表達(dá)式的組名。這樣在表達(dá)式或程序中可以直接引用組名,當(dāng)然也可以繼續(xù)使用組號(hào)。但如果正則表達(dá)式中同時(shí)存在普通捕獲組和命名捕獲組,那么捕獲組的編號(hào)就要特別注意,編號(hào)的規(guī)則是先對(duì)普通捕獲組進(jìn)行編號(hào),再對(duì)命名捕獲組進(jìn)行編號(hào)。
例如:
(\d{4})-(?date>\d{2}-(\d{2}))
1 1 3 2 23

下面在程序中處理命名捕獲組,顯示混合規(guī)則生成的組號(hào),并利用捕獲組的內(nèi)容對(duì)源字符串進(jìn)行替換。
可以看到先對(duì)普通捕獲組進(jìn)行編號(hào),再對(duì)命名捕獲組編號(hào)。
Regex.Replace方法
復(fù)制代碼 代碼如下:

using System.Text.RegularExpressions;
namespace Wuhong.Test
{
class Program
{
static void Main(string[] args)
{
//目標(biāo)字符串
string source = "http://reg-test-server:8080/download/file1.html# ";
//正則式,對(duì)其中兩個(gè)分組命名
string regex = @"(\w+):\/\/(?server>[^/:]+)(?port>:\d+)?([^# :]*)";
Regex regUrl = new Regex(regex);
//匹配正則表達(dá)式
Match m = regUrl.Match(source);
Console.WriteLine(m.Success);
if (m.Success)
{
//捕獲組存放在Match.Groups集合中,索引值從1開始,索引0處為匹配的整個(gè)字符串值
//按“組號(hào) : 捕獲內(nèi)容”的格式顯示
for (int i = 0; i m.Groups.Count; i++)
{
Console.WriteLine(string.Format("{0} : {1}", i, m.Groups[i]));
}
}
//替換字符串
//“$組號(hào)”引用捕獲組的內(nèi)容。
//需要特別注意的是“$組號(hào)”后不能跟數(shù)字形式的字符串,如果出現(xiàn)此情況,需要使用命名捕獲組,引用格式“${組名}”
string replacement = string.Format("$1://{0}{1}$2", "new-reg-test-server", "");
string result = regUrl.Replace(source, replacement);
Console.WriteLine(result);
Console.ReadLine();
}
}
}


非捕獲組
語法:

字符 

描述

示例

(?:pattern)

匹配pattern,但不捕獲匹配結(jié)果。

'industr(?:y|ies)

匹配'industry'或'industries'。

(?=pattern)

零寬度正向預(yù)查,不捕獲匹配結(jié)果。

'Windows (?=95|98|NT|2000)'

匹配 "Windows2000" 中的 "Windows"

不匹配 "Windows3.1" 中的 "Windows"。

(?!pattern)

零寬度負(fù)向預(yù)查,不捕獲匹配結(jié)果。

'Windows (?!95|98|NT|2000)'

匹配 "Windows3.1" 中的 "Windows"

不匹配 "Windows2000" 中的 "Windows"。

(?=pattern)

零寬度正向回查,不捕獲匹配結(jié)果。

'2000 (?=Office|Word|Excel)'

匹配 " Office2000" 中的 "2000"

不匹配 "Windows2000" 中的 "2000"。

(?!pattern)

零寬度負(fù)向回查,不捕獲匹配結(jié)果。

'2000 (?!Office|Word|Excel)'

匹配 " Windows2000" 中的 "2000"

不匹配 " Office2000" 中的 "2000"。


非捕獲組只匹配結(jié)果,但不捕獲結(jié)果,也不會(huì)分配組號(hào),當(dāng)然也不能在表達(dá)式和程序中做進(jìn)一步處理。
首先(?:pattern)與(pattern)不同之處只是在于不捕獲結(jié)果。
接下來的四個(gè)非捕獲組用于匹配pattern(或者不匹配pattern)位置之前(或之后)的內(nèi)容。匹配的結(jié)果不包括pattern。
例如:
(?=(\w+)>).*(?=\/\1>)匹配不包含屬性的簡(jiǎn)單HTML標(biāo)簽內(nèi)的內(nèi)容。如:div>hello/div>之中的hello,匹配結(jié)果不包括前綴div>和后綴/div>。
下面是程序中非捕獲組的示例,用來提取郵編。
可以看到反向回查和反向預(yù)查都沒有被捕獲。
Regex.Matches方法
復(fù)制代碼 代碼如下:

using System.Text.RegularExpressions;
namespace Wuhong.Test
{
class Program
{
static void Main(string[] args)
{
//目標(biāo)字符串
string source = "有6組數(shù)字:010001,100,21000,310000,4100011,510002,把郵編挑出來。";
//正則式
string regex = @"(?!\d)([1-9]\d{5})(?!\d)";
Regex regUrl = new Regex(regex);
//獲取所有匹配
MatchCollection mList = regUrl.Matches(source);
for (int j = 0; j mList.Count; j++)
{
//顯示每個(gè)分組,可以看到每個(gè)分組都只有組號(hào)為1的項(xiàng),反向回查和反向預(yù)查沒有被捕獲
for (int i = 0; i mList[j].Groups.Count; i++)
{
Console.WriteLine(string.Format("{0} : {1} : {2}", j, i, mList[j].Groups[i]));
}
}
Console.ReadLine();
}
}
}


注釋
語法:

字符

描述

示例

(?#comment)

comment是注釋,不對(duì)正則表達(dá)式的處理產(chǎn)生任何影響

2[0-4]\d(?#200-249)|25[0-5](?#250-255)|1?\d\d?(?#0-199)

匹配0-255的整數(shù)

這個(gè)不解釋了。

您可能感興趣的文章:
  • 正則表達(dá)式、分組、子匹配(子模式)、非捕獲子匹配(子模式)
  • JS正則表達(dá)式之非捕獲分組用法實(shí)例分析
  • javascript正則表達(dá)式中分組詳解
  • JS正則表達(dá)式獲取分組內(nèi)容的方法詳解
  • JavaScript正則表達(dá)式的分組匹配詳解
  • 淺談JavaScript正則表達(dá)式-非捕獲性分組

標(biāo)簽:綿陽 長(zhǎng)沙 泰州 重慶 無錫 宣城 銅川 西安

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《正則表達(dá)式之捕獲組/非捕獲組介紹》,本文關(guān)鍵詞  正則,表達(dá)式,之,捕獲,組,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《正則表達(dá)式之捕獲組/非捕獲組介紹》相關(guān)的同類信息!
  • 本頁收集關(guān)于正則表達(dá)式之捕獲組/非捕獲組介紹的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章