手机
当前位置:查字典教程网 >编程开发 >正则表达式 >关于preg_replace函数的问题讲解
关于preg_replace函数的问题讲解
摘要:请问下那此句语句的作用。给我解释一下其中的“?”,“e","i","s"符号分别是什么意思,和它们起到了什么作用。还有就是除了"/eis”外...

请问下那此句语句的作用。给我解释一下其中的“?”,“e","i","s"符号分别是什么意思,和它们起到了什么作用。还有就是除了"/eis”外还有其他什么模式了吗?

如果有相关的学习资料可以给我吗?谢谢,各位的帮助!谢谢。

$post=preg_replace("/[html](.+?)[/html]/eis","htmlcode('1')",$post);

修饰符:

在正则表达式里面的修饰符可以改变正则的很多特性,使得正则表达式更加适合你的需要(注意:修饰符对于大小写是敏感的,这意味着"e"并不等于"E")。正则表达式里面的修饰符如下:

i:如果在修饰符中加上"i",则正则将会取消大小写敏感性,即"a"和"A"是一样的。

m:默认的正则开始"^"和结束"$"只是对于正则字符串如果在修饰符中加上"m",那么开始和结束将会指字符串的每一行:每一行的开头就是"^",结尾就是"$"。

s:如果在修饰符中加入"s",那么默认的"."代表除了换行符以外的任何字符将会变成任意字符,也就是包括换行符!

x:如果加上该修饰符,表达式中的空白字符将会被忽略,除非它已经被转义。

e:本修饰符仅仅对于replacement有用,代表在replacement中作为PHP代码。

A:如果使用这个修饰符,那么表达式必须是匹配的字符串中的开头部分。比如说"/a/A"匹配"abcd"。

E:与"m"相反,如果使用这个修饰符,那么"$"将匹配绝对字符串的结尾,而不是换行符前面,默认就打开了这个模式。

U:和问号的作用差不多,用于设置"贪婪模式"。

?表单非贪婪匹配,即尽可能少的匹配和

[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]中间的内容

e表示可以使用函数来处理向后引后的子匹配部分

i表未不区分大小写,

s表示.也匹配换行符

假设有如下字符串

this is a text

[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]this is another text

[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]

使用/[html](.+?)[/html]/和使用[html](.+)[/html]/U的结果是一样的,

都是代表非贪婪,只不过一个用了修正符,一个用了语法。

结果是this is a text

[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]和this is another text

[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]

两个匹配,

而/[html](.+)[/html]/的结果是

this is a text

[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]this is another text

[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]一个匹配

因为整个字符也是符合以""开头以"

[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]"结尾,只不过是获得更多的字符串

【关于preg_replace函数的问题讲解】相关文章:

javascript中基于replace函数的正则表达式语法

解决preg_match匹配过多字符长度的限制的思路分析

js正则表达式之match函数讲解

深入分析正则表达式的子模式

js replace正则相关的诡异问题

php正则之函数 preg_replace()参数说明

值得收藏的正则表达式大全

js正则表达式常用函数详解(续)

关于HTML及UBB标记的闭合

自定义ubb代码,preg_replace()函数的一些代码

精品推荐
分类导航