[数据结构与算法]模式匹配与文本处理-零宽度正预测先行断言 and 零宽度正回顾后发断言

msdn中的描述如下:

(?= 子表达式)

(零宽度正预测先行断言。) 仅当子表达式在此位置的右侧匹配时才继续匹配。例如,\w+(?=\d) 与后跟数字的单词匹配,而不与该数字匹配。此构造不会回溯

(?<= 子表达式)

(零宽度正回顾后发断言。) 仅当子表达式在此位置的左侧匹配时才继续匹配。例如,(?<=19)99 与跟在 19 后面的 99 的实例匹配。此构造不会回溯

msdn描述的比较清楚,

如:\w+(?=ing) 可以匹配以ing结尾的单词(匹配结果不包括ing),

(?<=Red-)\w+,匹配Red- 后边的单词。


 1

using System;
 2

using System.Collections.Generic;
 3

using System.Text;
 4

using System.Text.RegularExpressions;
 5


 6

namespace practice
 7

{
 8

    
public class myclass
 9

    
{
10

        
static void Main() {
11

            Regex pattern1 
= new Regex(@"(?<=Red-)\w{3}");
12


13

            MatchCollection match 
= pattern1.Matches("Red-abc");//Only get "abc"
14

            
foreach (Match one in match) {
15

                System.Console.WriteLine(
===="+one.Value);
16

            }

17


18

            pattern1 
= @"Red-(?<=Red-)\w{3{19


20

            match 
= pattern1.Matches(");//Could get the whole word including "Red-"
21

            
in match) {
22

                System.Console.WriteLine(
+++++" + one.Value);
23

            }

24

            
return;
25

        }

26

    }

27

}

 

下面讲下我的理解:

(1).零宽度

这表示匹配是一个位置(Loaction)而不是子表达式。

(2).预测先行,回顾后发

(?= 子表达式),预测先行, 返回与子表达式匹配的前面位置,从做左到右匹配。

(?<= 子表达式),回顾后发,返回与子表达式匹配的后边位置,从右到左匹配。

我们可以想象有在模式匹配过程中有一指针标志当前匹配的位置,这样当子表达式匹配时 预测先行 把指针指到子表达式前边,回顾后发则为后边。可以参考上边代码

转自:http://www.cnblogs.com/creek/archive/2009/04/04/1429600.html

相关文章

【啊哈!算法】算法3:最常用的排序——快速排序       ...
匿名组 这里可能用到几个不同的分组构造。通过括号内围绕的正...
选择排序:从数组的起始位置处开始,把第一个元素与数组中其...
public struct Pqitem { public int priority; ...
在编写正则表达式的时候,经常会向要向正则表达式添加数量型...
来自:http://blog.csdn.net/morewindows/article/details/6...