假设有如下字符串 [html]this is a text[/html][html]this is another text[/html] 使用/\[html\](.+?)\[\/html\]/和使用[html\](.+)\[\/html\]/U的结果是一样的, 都是代表非贪婪,只不过一个用了修正符,一个用了语法。 结果是[html]this is a text[/html]和[html]this is another text[/html] 两个匹配, 而/\[html\](.+)\[\/html\]/的结果是 [html]this is a text[/html][html]this is another text[/html]一个匹配 因为整个字符也是符合以"[html]"开头以"[/html]"结尾,只不过是获得更多的字符串
在正则表达式里面的修饰符可以改变正则的很多特性,使得正则表达式更加适合你的需要(注意:修饰符对于大小写是敏感的,这意味着"e"并不等于"E")。正则表达式里面的修饰符如下:
i :如果在修饰符中加上"i",则正则将会取消大小写敏感性,即"a"和"A" 是一样的。
m:默认的正则开始"^"和结束"$"只是对于正则字符串如果在修饰符中加上"m",那么开始和结束将会指字符串的每一行:每一行的开头就是"^",结尾就是"$"。
s:如果在修饰符中加入"s",那么默认的"."代表除了换行符以外的任何字符将会变成任意字符,也就是包括换行符!
x:如果加上该修饰符,表达式中的空白字符将会被忽略,除非它已经被转义。
e:本修饰符仅仅对于replacement有用,代表在replacement中作为PHP代码。
A:如果使用这个修饰符,那么表达式必须是匹配的字符串中的开头部分。比如说"/a/A"匹配"abcd"。
E:与"m"相反,如果使用这个修饰符,那么"$"将匹配绝对字符串的结尾,而不是换行符前面,默认就打开了这个模式。
U:和问号的作用差不多,用于设置"贪婪模式"。
e表示可以使用函数来处理向后引后的子匹配部分
i表未不区分大小写,
s表示.也匹配换行符
js的正则表达式与perl的正则表达式基本一致,而jscript用户手册是最容易找到的电子文档。做网页也是离不开他的
[html]this is a text[/html][html]this is another text[/html]
使用/\[html\](.+?)\[\/html\]/和使用[html\](.+)\[\/html\]/U的结果是一样的,
都是代表非贪婪,只不过一个用了修正符,一个用了语法。
结果是[html]this is a text[/html]和[html]this is another text[/html]
两个匹配,
而/\[html\](.+)\[\/html\]/的结果是
[html]this is a text[/html][html]this is another text[/html]一个匹配
因为整个字符也是符合以"[html]"开头以"[/html]"结尾,只不过是获得更多的字符串
open
replace
print