转 PHP 正则表达式 以及案例
2.Perl兼容的语法扩充 Perl兼容的正则表达式的模式类似于Perl中的语法,表达式必须包含在定界符中,除数字、字母、反斜线外的任何字符都可以作为定界符。例如,表达式’/^(?i)php[34]/’中正斜线“/”就是定界符。另外,如果定界符要出现在表达式中需要使用转义符转义。 1.以下是几个简单的正则表达式的例子。 ‘[A-Za-z0-9] ‘:表示所有的大写字母、小写字母及0到9的数字。 ‘^hello’:表示以hello开始的字符串。 ‘world$’:表示以world结尾的字符串。 ‘.at’:表示以除”\n”外的任意单个字符开头并以”at”结尾的字符串,如”cat”、”nat”等。 ‘^[a-zA-Z]’:表示一个以字母开头的字符串。 ‘hi{2}’:表示字母h后跟着两个i即hii。 ‘(go)+’:表示至少含有一个’go’字符串的字符串,如’gogo’。
3.
(1)“+”元字符规定其前导字符必须在目标对象中连续出现一次或多次
比如:/php+/,能够与“phpp”匹配,即字母ph后面连续出现一个或多个字母p的字符串相匹配。
(2)“*”元字符规定其前导字符必须在目标对象中出现零次或连续多次
比如:/php*/能够与“phpddt”相匹配,即ph后面可以有0个或多个p
(3)“?”元字符规定其前导对象必须在目标对象中连续出现零次或一次。
比如:/php?/能够“pher”匹配,即phh后面可以有0个或者1个p
4.案例
函数如果提供了$matches参数,则其会被搜索的结果所填充。$matches[0]将包含与整个模式匹配的文本,$matches[1]将包含与第一个捕获的括号中的子模式所匹配的文本,
以此类推。例如:
说明如下:
-》 [^\/] ”[]”只能匹配单个字符,
-》 (http:\/\/) 括号字符() 改变限定符如(|、* 、^)的作用范围
-》 正则表达式提供了”^”来表示排除不符合的字符,^一般放在[]中。如[^1-5],该字符不是1~5之间的数字。
-》 \ 转义符
案例如下:
<?php
$string="http://www.php.net/index.html";
preg_match('/^(http:\/\/)?([^\/]+)/i', $string, $matches1);
//从URL中取得主机名, partten 为 以“http://”开头,? 代表出现0次或一次;排除[^\/] 为排除/,一次或多次为结尾的。
print_r($matches1);
echo "<br/>";
echo $matches1[0]; //输出http://www.php.net
echo "<br/>";
echo $matches1[1]; //输出http://
// 第一个括号为的patten
echo "<br/>";
echo $matches1[2]; //输出www.php.net
echo "<br/>";
$host=$matches1[2];
echo $host; //输出www.php.net
echo "<br/>";
preg_match('/[^\.\/]+\.[^\.\/]+$/', $host, $matches2);
//从主机名中取得后面两段;
//partten 为 以非“.”“/”开头,(一次或多次),中间有一个“.", 末尾以非“.”“/”结尾;(一次或多次)。
echo "域名为:$matches2[0]"; //输出"域名为:php.net"
?>
5.
http://www.cnblogs.com/hellohell/p/5718319.html
正则表达式的基本知识汇总
行定位符(^与$)
行定位符是用来描述字符串的边界。“$”
表示行结尾“^”
表示行开始如"^de"
,表示以de开头的字符串 "de$"
,表示以de结尾的字符串。
单词定界符
我们在查找的一个单词的时候,如an是否在一个字符串”gril and body”中存在,很明显如果匹配的话,an肯定是可以匹配字符串“gril and body”匹配到,怎样才能让其匹配单词,而不是单词的一部分呢?这时候,我们可以是哟个单词定界符\b。
\ban\b 去匹配”gril and body”的话,就会提示匹配不到。
当然还有一个大写的\B,它的意思,和\b正好相反,它匹配的字符串不能使一个完整的单词,而是其他单词或字符串中的一部分。如\Ban\B。
选择字符(|) ,表示或
选择字符表示或的意思。如Aa|aA,表示Aa或者是aA的意思。注意使用”[]”与”|”的区别,在于”[]”只能匹配单个字符,而”|”可以匹配任意长度的字符串。在使用”[]”的时候,往往配合连接字符”-“一起使用,如[a-d],代表a或b或c或d。
排除字符,排除操作
正则表达式提供了”^”来表示排除不符合的字符,^一般放在[]中。如[^1-5],该字符不是1~5之间的数字。
限定符(?*+{n,m})
限定符主要是用来限定每个字符串出现的次数。
限定字符 | 含义 |
---|---|
? | 零次或一次 |
* | 零次或多次 |
+ | 一次或多次 |
{n} | n次 |
{n,} | 至少n次 |
{n,m} | n到m次 |
如(D+)表示一个或多个D
点号操作符
匹配任意一个字符(不包含换行符)
表达式中的反斜杠(\
)
表达式中的反斜杠有多重意义,如转义、指定预定义的字符集、定义断言、显示不打印的字符。
转义字符
转义字符主要是将一些特殊字符转为普通字符。而这些常用特殊字符有”.”,”?”、”\”等。
指定预定义的字符集
字符 | 含义 |
---|---|
\d | 任意一个十进制数字[0-9] |
\D | 任意一个非十进制数字 |
\s | 任意一个空白字符(空格、换行符、换页符、回车符、字表符) |
\S | 任意一个非空白字符 |
\w | 任意一个单词字符 |
\W | 任意个非单词字符 |
###显示不可打印的字符
字符 | 含义 |
---|---|
\a | 报警 |
\b | 退格 |
\f | 换页 |
\n | 换行 |
\r | 回车 |
\t | 字表符 |
括号字符()
在正则表达式中小括号的作用主要有:
- 改变限定符如(|、* 、^)的作用范围
如(my|your)baby,如果没有”()”,|将匹配的是要么是my,要么是yourbaby,有了小括号,匹配的就是mybaby或yourbaby。 - 进行分组,便于反向引用
反向引用
反向引用,就是依靠子表达式的”记忆”功能,匹配连续出现的字串或是字符。如(dqs)(pps)\1\2,表示匹配字符串dqsppsdqspps。在下面php应用中,我将详细展开学习反向引用。
模式修饰符
模式修饰符的作用是设定模式,也就是正则表达式如何解释。php中主要模式如下表:
修饰符 | 说明 |
---|---|
i | 忽略大小写 |
m | 多文本模式 |
s | 单行文本模式 |
x | 忽略空白字符 |
正则表达式在php中应用