您的位置:首页 > 编程语言 > C#

C#正则表达式整理备忘(四)

2009-11-14 14:58 274 查看
C#正则表达式整理备忘(四)

(9)回溯与非回溯
使用“(?>…)”方式进行非回溯声明。由于正则表达式引擎的贪婪特性,导致它在某些情况下,将进行回溯以获得匹配,请看下面的示例:(10)正向预搜索、反向预搜索
正向预搜索声明格式:正声明 “(?=…)”,负声明 “(?!...)” ,声明本身不作为最终匹配结果的一部分,请看下面的示例:反向预搜索声明格式:正声明“(?<=)”,负声明“(?<!)”,声明本身不作为最终匹配结果的一部分,请看下面的示例:(11)十六进制字符范围
正则表达式中,可以使用 "/xXX" 和 "/uXXXX" 表示一个字符("X" 表示一个十六进制数)形式字符范围:
/xXX 编号在 0到255 范围的字符,比如:空格可以使用 "/x20" 表示。
/uXXXX 任何字符可以使用 "/u" 再加上其编号的4位十六进制数表示,比如:汉字可以使用“[/u4e00-/u9fa5]”表示。




Code


string x = "Live for nothing,die for something";


Regex r1 = new Regex(@".*thing,");


if (r1.IsMatch(x))






{


Console.WriteLine("match:" + r1.Match(x).Value);//输出:Live for nothing,


}


Regex r2 = new Regex(@"(?>.*)thing,");


if (r2.IsMatch(x))//不匹配






{


Console.WriteLine("match:" + r2.Match(x).Value);


}


//在r1中,“.*”由于其贪婪特性,将一直匹配到字符串的最后,随后匹配“thing”,但在匹配“,”时失败,此时引擎将回溯,并在“thing,”处匹配成功。


在r2中,由于强制非回溯,所以整个表达式匹配失败。






Code


string x = "1024 used 2048 free";


Regex r1 = new Regex(@"/d{4}(?= used)");


if (r1.Matches(x).Count==1)






{


Console.WriteLine("r1 match:" + r1.Match(x).Value);//输出:1024


}


Regex r2 = new Regex(@"/d{4}(?! used)");


if (r2.Matches(x).Count==1)






{


Console.WriteLine("r2 match:" + r2.Match(x).Value); //输出:2048


}


//r1中的正声明表示必须保证在四位数字的后面必须紧跟着“ used”,r2中的负声明表示四位数字之后不能跟有“ used”。






Code


string x = "used:1024 free:2048";


Regex r1 = new Regex(@"(?<=used:)/d{4}");


if (r1.Matches(x).Count==1)






{


Console.WriteLine("r1 match:" + r1.Match(x).Value);//输出:1024


}


Regex r2 = new Regex(@"(?<!used:)/d{4}");


if (r2.Matches(x).Count==1)






{


Console.WriteLine("r2 match:" + r2.Match(x).Value);//输出:2048


}


//r1中的反向正声明表示在4位数字之前必须紧跟着“used:”,r2中的反向负声明表示在4位数字之前必须紧跟着除“used:”之外的字符串。



(12)对[0,100]的比较完备的匹配
下面是一个比较综合的示例,对于匹配[0,100],需要特殊考虑的地方包括
*00合法,00.合法,00.00合法,001.100合法
*空字符串不合法,仅小数点不合法,大于100不合法
*数值是可带后缀的,如“1.07f”表示该值为一个float类型(未考虑)




Code


Regex r = new Regex(@"^/+?0*(?:100(/.0*)?|(/d{0,2}(?=/./d)|/d{1,2}(?=($|/.$)))(/./d*)?)$");


string x = "";


while (true)






{


x = Console.ReadLine();


if (x != "exit")






{


if (r.IsMatch(x))






{


Console.WriteLine(x + " succeed!");


}


else






{


Console.WriteLine(x + " failed!");


}


}


else






{


break;


}


}



13)精确匹配有时候是困难的
有些需求要做到精确匹配比较困难,例如:日期、Url、Email地址等,其中一些你甚至需要研究一些专门的文档写出精确完备的表达式,对于这种情况,只能退而求其次,保证比较精确的匹配。例如对于日期,可以基于应用系统的实际情况考虑一段较短的时间,或者对于像Email的匹配,可以只考虑最常见的形式。

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: