09月
16
配合实例,一步一步学习php正则
文章分类:PHP 查看次数:765 + 120
对于正则,如果不理解的话,那根本就没法看,一堆数字和符号,头都大了,可是要成为一个合格的程序员,正则是必须要跨过的一个坎。
原文地址:http://weblogtoolscollection.com/regex/regex.php
基本语法:
"^The":以"The"开头
"of despair$":以"of despair"结尾
"^abc$":字符串"abc"
"notice":包含"notice"的字符串
就像最后一个例子一样,如果没有定义边界符号,就相当于在当前字符串里查找该字符串。
最常用的"*","+","?"分别指"出现0次或多次","出现1次或多次","出现0次或1次"
"ab*":匹配"a","ab","abbb"
"ab+":匹配"ab","abbb",不匹配"a"
"ab?":没有"b",或者只有一个"b"
"a?b+$":以字符b结尾(a?可以忽略)
也可以定义个数,这个是以大括号来表现的
"ab{2}":只匹配"abb"
"ab{2,}":至少有2个b
"ab{3,5}": b的个数在3-5之间,包括3,5
必须指定第一个参数,如{,3}是无效的
现在合并在一起来看看
"a(bc)*":匹配一个字符串,这个字符串必须以a或者n个bc结尾,如"a,abc,abcbc"
"a(bc){1,5}":bc字符串可以出现
"|"表示的关系是"或"
"hi|hello":匹配hi或者hello
"(b|cd)ef":一个包含"bef"或者"cdef"的字符串
"(a|b)*c":字符串可以包含"ac","bc","c","aac"
"."用来匹配任意单个字符
"a.[0-9]":这个字符串只要以a开头数字结尾就行,中间可以是任意数,当然只能有一个
"^.{3}$":匹配任意3个字符
中括号说明单个字符的类型
"[ab]":匹配一个字符串,这个字符串只能包含a或者b
"[a-d]":这个字符串可以包含a到d之间的字母
"^[a-zA-Z]":以字母开头
"[0-9]%":0%-9%
",[a-zA-Z0-9]$":以单个字母或数字结束,但前面必须要有个逗号
也可以列出不想要的字符,用"^"就可以了
"%[^a-zA-Z]%": 两个%之间,只要不是字母就行
为了避免错误,系统的关键符号需要转义"^.[$()|*+?{\",加上一个"\"就行了
例1:有效的正则
* /<\/\w+>/
* |(\d{3})-\d+|Sm
* /^(?i)php[34]/
* {^\s+(\s+)?$}
例2:无效的正则
* /href='(.*)' - 没有定义结束符号
* /\w+\s*\w+/J - 参数J,无意义
* 1-\d3-\d3-\d4| - 缺少开始符号
一些有用的php函数,以及一些例子
preg_split
array preg_split ( string pattern, string subject [, int limit [, int flags]])
演示1:以空格,逗号,回车,tab为分割符,分割字符串
演示2:取得组成字符串的字母
$str = 'string';
$chars = preg_split('//', $str, -1, PREG_SPLIT_NO_EMPTY);
print_r($chars);
?>
演示3:分割一个字符串,同时取得它在原字符串中的位置
$str = 'hypertext language programming';
$chars = preg_split('/ /', $str, -1, PREG_SPLIT_OFFSET_CAPTURE);
print_r($chars);
结果输出
(
[0] => Array
(
[0] => hypertext
[1] => 0
)
[1] => Array
(
[0] => language
[1] => 10
)
[2] => Array
(
[0] => programming
[1] => 19
)
)
preg_match
int preg_match ( string pattern, string subject [, array matches [, int flags]])
演示1:寻找字符串"php",参数"i"忽略大小写
print "A match was found.";
} else {
print "A match was not found.";
}
演示2:寻找单词"web" \b定义边界符
if (preg_match ("/\bweb\b/i", "PHP is the web scripting language of choice.")) {
print "A match was found.";
} else {
print "A match was not found.";
}
if (preg_match ("/\bweb\b/i", "PHP is the website scripting language of choice.")) {
print "A match was found.";
} else {
print "A match was not found.";
}
?>
演示3:得到一个url的域名信息
"http://www.php.net/index.html", $matches);
$host = $matches[2];
// 取得域名的最后两位
preg_match("/[^\.\/]+\.[^\.\/]+$/", $host, $matches);
echo "domain name is: {$matches[0]}\n";
相关文章
评论
发表评论

