正则表达式文字符号

发布人:kimi  时间:2007-11-06 22:46  来源: 收集整理  查看: 479次   TAG: PHP正则  文字符号 

最基本的正则表达式由单个文字符号组成。如<<a>>,它将匹配字符串中第一次出现的字符“a”。如对字符串“Jack is a boy”。“J”后的“a”将被匹配。而第二个“a”将不会被匹配。


正则表达式也可以匹配第二个“a”,这必须是你告诉正则表达式引擎从第一次匹配的地方开始搜索。在文本编辑器中,你可以使用“查找下一个”。在编程语言中,会有一个函数可以使你从前一次匹配的位置开始继续向后搜索。


类似的,<<cat>>会匹配“About cats and dogs”中的“cat”。这等于是告诉正则表达式引擎,找到一个<<c>>,紧跟一个<<a>>,再跟一个<<t>>


要注意,正则表达式引擎缺省是大小写敏感的。除非你告诉引擎忽略大小写,否则<<cat>>不会匹配“Cat”。


 


·        特殊字符


对于文字字符,有11个字符被保留作特殊用途。他们是:


[ ] \ ^ $ . | ? * + ( )


这些特殊字符也被称作元字符。


如果你想在正则表达式中将这些字符用作文本字符,你需要用反斜杠“\”对其进行换码 (escape)。例如你想匹配“1+1=2”,正确的表达式为<<1\+1=2>>.


需要注意的是,<<1+1=2>>也是有效的正则表达式。但它不会匹配“1+1=2”,而会匹配“123+111=234”中的“111=2”。因为“+”在这里表示特殊含义(重复1次到多次)。


在编程语言中,要注意,一些特殊的字符会先被编译器处理,然后再传递给正则引擎。因此正则表达式<<1\+2=2>>C++中要写成“1\\+1=2”。为了匹配“C:\temp”,你要用正则表达式<<C:\\temp>>。而在C++中,正则表达式则变成了“C:\\\\temp”。


 


·        不可显示字符


可以使用特殊字符序列来代表某些不可显示字符:


<<\t>>代表Tab(0x09)


<<\r>>代表回车符(0x0D)


<<\n>>代表换行符(0x0A)


要注意的是Windows中文本文件使用“\r\n”来结束一行而Unix使用“\n”。

相关阅读

本月热门