新蒲京200.c软件下载-app官网网址 > 活动 >

其次个是链接文本

正则表明式用于字符串处理、表单验证等场合,实用高效。本文采撷了某个常用的表明式:

$str = preg_replace("/(<a.*?>)(.*?)(</a>)/", '123', $str);

当中用了八个子格局(各样圆括号中内容为三个子形式),第三个是链接开首标签,首个是链接文本,首个是</a>

接下来第贰个参数中1、2、3就意味着这三个部分,要替换到什么样子还不简单?

收获页面中的全体链接地址的PHP函数

上面这一个用PHP写的函数,能够获取大肆的字符串$string中的全部链接地址($string能够是从一个HTML页面文件直接读抽出来的字符串卡塔尔(قطر‎,结果保存在三个数组中重返.该函数自动把电子邮件地址清除在外,而且回去的数组中不会有重新成分.

function GetAllLink($string) 
{ 
$string = str_replace("r","",$string); 
$string = str_replace("n","",$string); 

$regex[url] = "((http|https|ftp|telnet|news)://)?([a-z0-9_-/.]+.[][a-z0-9:;&#@=_~%?/.,+-]+)"; 
$regex[email] = "([a-z0-9_-]+)@([a-z0-9_-]+.[a-z0-9-._-]+)"; 

//去掉标签之间的文字 
$string = eregi_replace(">[^<>]+<","><", $string); 

//去掉JAVASCRIPT代码 
$string = eregi_replace("<!--.*//-->","", $string); 

//去掉非<a>的HTML标签 
$string = eregi_replace("<[^a][^<>]*>","", $string); 

//去掉EMAIL链接 
$string = eregi_replace("<a([ ]+)href=(["']*)mailto:($regex[email])(["']*)[^>]*>","", $string); 

//替换需要的网页链接 
$string = eregi_replace("<a([ ]+)href=(["']*)($regex[url])(["']*)[^>]*>","\3t", $string); 

$output[0] = strtok($string, "t"); 
while(($temp = strtok("t"))) 
{ 
if($temp && !in_array($temp, $output)) 
$output[++$i] = $temp; 
} 

return $output; 
}

以下是以PHP的语法所写的为人师表

验证字符串是不是只含数字与意大利语,字符串长度并在4~15个字符之间

<?php 
$str = 'a1234'; 
if (preg_match("^[a-zA-Z0-9]{4,16}$", $str)) { 
echo "验证成功";} else { 
echo "验证失敗";}?>

简言之的西藏质量证字号验证

<?php 
$str = 'a1234'; 
if (preg_match("^(?:d{15}|d{18})$", $str)) { 
echo "验证成功"; 
} else { 
echo "验证失敗";} 
?>

上面的代码完结文字中的代码块,成效犹如您在本子之家见到的代码相仿。

function codedisp($code) { 
global $discuzcodes; 
$discuzcodes['pcodecount']++; 
$code = htmlspecialchars(str_replace('\"', '"', preg_replace("/^[nr]*(.+?)[nr]*$/is", "\1", $code))); 
$discuzcodes['codehtml'][$discuzcodes['pcodecount']] = "<br><div class="msgheader"><div class="right"><a href="###" class="smalltxt" onclick="copycode($('phpcode$discuzcodes[codecount]'));">[复制此代码]</a></div>代码如下:</div><div class="msgborder" id="phpcode$discuzcodes[codecount]">".fhtml2($code)."</div><br>"; 
$discuzcodes['codecount']++; 
return "[tDISCUZ_CODE_$discuzcodes[pcodecount]t]"; 
} 
$message = preg_replace("/s*[code](.+?)[/code]s*/ies", "codedisp('\1')", $message); 
$message = preg_replace("/s*[html](.+?)[/html]s*/ies", "htmldisp('\1')", $message);

同盟汉语字符的正则表明式: [u4e00-u9fa5]
评注:相称粤语还真是个咳嗽的事,有了这一个表达式就好办了

十三分双字节字符(包涵汉字在内卡塔尔:[^x00-xff]
评注:能够用来测算字符串的长度(二个双字节字符长度计2,ASCII字符计1)

相称空白行的正则表达式:ns*r
评注:能够用来删除空白行

相配HTML标识的正则表明式:<(S*?)[^>]*>.*?</1>|<.*? />
评注:网络流传的版本太不好,上边那几个也单独能合营部分,对于复杂的嵌套标记依旧不可能

相称首尾空白字符的正则表明式:^s*|s*$
评注:能够用来删除行首行尾的空白字符(包蕴空格、制表符、换页符等等卡塔尔国,极其常有效的表达式

相称Email地址的正则表明式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
评注:表单验证时很实用

匹配网站UHavalL的正则表明式:[a-zA-z]+://[^s]*
评注:互连网流传的本子效果很有限,下边那一个大旨能够满意需要

合营帐号是或不是合法(字母开始,允许5-16字节,允许字母数字下划线State of Qatar:^[a-zA-Z][a-zA-Z0-9_]{4,15}$
评注:表单验证时很实用

协作国内电话号码:d{3}-d{8}|d{4}-d{7}
评注:相称方式如 0511-4405222 或 021-87888822

相配TencentQQ号:[1-9][0-9]{4,}
评注:腾讯QQ号从10000开始

相当中夏族民共和国邮编:[1-9]d{5}(?!d)
评注:中华夏儿女民共和国邮编为6位数字

合营居民身份证:d{15}|d{18}
评注:中华夏族民共和国的居民身份证为拾多个人或22人

匹配ip地址:d+.d+.d+.d+
评注:提取ip地址时有用

非常特定数字:

^[1-9]d*$    //匹配正整数
 ^-[1-9]d*$   //匹配负整数
 ^-?[1-9]d*$   //匹配整数
 ^[1-9]d*|0$  //匹配非负整数(正整数 + 0)
 ^-[1-9]d*|0$   //匹配非正整数(负整数 + 0)
 ^[1-9]d*.d*|0.d*[1-9]d*$   //匹配正浮点数
 ^-([1-9]d*.d*|0.d*[1-9]d*)$  //匹配负浮点数
 ^-?([1-9]d*.d*|0.d*[1-9]d*|0?.0+|0)$  //匹配浮点数
 ^[1-9]d*.d*|0.d*[1-9]d*|0?.0+|0$   //匹配非负浮点数(正浮点数 + 0)
 ^(-([1-9]d*.d*|0.d*[1-9]d*))|0?.0+|0$  //匹配非正浮点数(负浮点数 + 0)

评注:管理大批量数据时有用,具体行使时只顾改正

特别特定字符串:

^[A-Za-z]+$  //匹配由26个英文字母组成的字符串
 ^[A-Z]+$  //匹配由26个英文字母的大写组成的字符串
 ^[a-z]+$  //匹配由26个英文字母的小写组成的字符串
 ^[A-Za-z0-9]+$  //匹配由数字和26个英文字母组成的字符串
 ^w+$  //匹配由数字、26个英文字母或者下划线组成的字符串

下边是一对特殊字符:

正则表明式中的特殊字符: (学习参谋书-<<明白正则表达式>>)

字符
意义:对于字符,平常表示按字面意思,提出接着的字符为特殊字符,不作解释。
诸如:/b/相配字符'b',通过在b 后面加三个反斜杠,也正是/b/,则该字符产生特殊字符,表示
同盟叁个单词的分水岭。
或者:
对于多少个字符,通常表达是出格的,建议紧接着的字符不是出格的,而应该按字面解释。
例如:*是三个特殊字符,相称大几个字符(包含0个字符卡塔尔(قطر‎;举个例子:/a*/意味相配0个或多个a。
为了协作字面上的*,在a前边加一个反斜杠;比如:/a*/匹配'a*'。

字符^
意思:表示卓殊的字符必需在最前边。
举例说:/^A/不包容"an A,"中的'A',但非常"An A."中最前边的'A'。

字符$
意思:与^肖似,相称最末的字符。
例如:/t$/不匹配"eater"中的't',但匹配"eat"中的't'。

字符*
意义:匹配*前方的字符0次或n次。
例如:/bo*/相配"A ghost booooed"中的'boooo'或"A bird warbled"中的'b',但不相称"A goat g
runted"中的任何字符。

字符+
意义:相称+号前边的字符1次或n次。等价于{1,}。
比如:/a+/相配"candy"中的'a'和"caaaaaaandy."中的全部'a'。

字符?
意思:相称?前边的字符0次或1次。
例如:/e?le?/匹配"angel"中的'el'和"angle."中的'le'。

字符.
意义:(小数点卡塔尔(قطر‎匹配除换行符外的保有单个的字符。
比方说:/.n/匹配"nay, an apple is on the tree"中的'an'和'on',但不相配'nay'。

字符(x)
意义:相称'x'并记录相称的值。
比如说:/(foo卡塔尔/相配和记录"foo bar."中的'foo'。匹配子串能被结果数组中的素[1], ..., [n] 返
回,或被RegExp对象的天性$1, ..., $9重返。

字符x|y
意义:匹配'x'或者'y'。
例如:/green|red/匹配"green apple"中的'green'和"red apple."中的'red'。

字符{n}
意思:这里的n是三个正整数。匹配后面包车型客车n个字符。
比方说:/a{2}/不宽容"candy,"中的'a',但非凡"caandy," 中的全部'a'和"caaandy."中前边的多个
'a'。

字符{n,}
意义:这里的n是叁个正整数。相称起码n个前边的字符。
比方:/a{2,}不相配"candy"中的'a',但格外"caandy"中的全部'a'和"caaaaaaandy."中的全体'a'

字符{n,m}
意思:这里的n和m都以正整数。相配最少n个最多m个前边的字符。
比方:/a{1,3}/不包容"cndy"中的任何字符,但匹配"candy,"中的'a',"caandy," 中的后面多个
'a'和"caaaaaaandy"中前面包车型客车四个'a',注意:即便"caaaaaaandy" 中有许多少个'a',但只十一分前面的三
个'a'即"aaa"。

字符[xyz]
意思:一字符列表,匹配列出中的任一字符。你能够透过连字符-提出八个字符范围。
例如:[abcd]跟[a-c]平等。它们相配"brisket"中的'b'和"ache"中的'c'。

字符[^xyz]
意思:一字符补集,也便是说,它匹配除了列出的字符外的具有东西。 你能够接收连字符-建议一
字符范围。
例如:[^abc]和[^a-c]极度,它们最初相称"brisket"中的'r'和"chop."中的'h'。

字符
意义:相配一个空格(不要与b混淆卡塔尔国

字符b
意思:相称三个单词的汾水陵,比方贰个空格(不要与混淆卡塔尔
例如:/bnw/匹配"noonday"中的'no',/wyb/匹配"possibly yesterday."中的'ly'。

字符B
意思:相配二个单词的非分水岭
例如:/wBn/匹配"noonday"中的'on',/yBw/匹配"possibly yesterday."中的'ye'。

字符cX
意思:这里的X是三个调控字符。相配叁个字符串的调节字符。
譬喻:/cM/相称三个字符串中的control-M。

字符d
意思:相配二个数字,等价于[0-9]。
例如:/d/或/[0-9]/匹配"B2 is the suite number."中的'2'。

字符D
意义:相配任何的非数字,等价于[^0-9]。
例如:/D/或/[^0-9]/匹配"B2 is the suite number."中的'B'。

字符f
意思:相配二个表单符

字符n
意思:相配三个换行符

字符r
意思:相称三个回车符

字符s
意义:相称三个单个white空格符,富含空格,tab,form feed,换行符,等价于[ fnrtv]。
例如:/sw*/匹配"foo bar."中的' bar'。

字符S
意义:相称除white空格符以外的八个单个的字符,等价于[^ fnrtv]。
例如:/S/w*匹配"foo bar."中的'foo'。

字符t
意思:相配八个制表符

字符v
意思:相称贰个顶头制表符

字符w
意义:相配全部的数字和字母以至下划线,等价于[A-Za-z0-9_]。
例如:/w/匹配"apple,"中的'a',"$5.28,"中的'5'和"3D."中的'3'。

字符W
意思:相配除数字、字母外及下划线外的其他字符,等价于[^A-Za-z0-9_]。
例如:/W/或者/[^$A-Za-z0-9_]/匹配"50%."中的'%'。

字符n
意思:这里的n是一个正整数。相称二个正则表明式的末尾一个子串的n的值(计数左圆括号State of Qatar。

例如:/apple(,)sorange1/匹配"apple, orange, cherry, peach."中的'apple, orange',下面
有多个进一层完整的例子。
只顾:借使左圆括号中的数字比n钦赐的数字还小,则n取下一行的八进制escape作为描述。

字符ooctal和xhex
意义:这里的ooctal是四个八进制的escape值,而xhex是二个十九进制的escape值,允许在三个正则表明式中寄放ASCII码。

通用情势

定界符,平常使用 "/"做为定界符伊始和了结,也足以运用"#"。

哪些时候利用"#"呢?常常是在你的字符串中有比超多"/"字符的时候,因为正则的时候这种字符要求转义,比如uri。
动用"/"定界符的代码如下.

<?php 
$regex = '/^http://([w.]+)/([w]+)/([w]+).html$/i'; 
$str = 'http://www.youku.com/show_page/id_ABCDEFG.html'; 
$matches = array(); 
if(preg_match($regex, $str, $matches)){ 
var_dump($matches); 
} 
echo "n";

preg_match中的$matches[0]将含有与成套格局相称的字符串。

使用"#"定界符的代码如下.那个时候对"/"就不转义!

$regex = '#^http://([w.]+)/([w]+)/([w]+).html$#i'; 
$str = 'http://www.youku.com/show_page/id_ABCDEFG.html'; 
$matches = array(); 
if(preg_match($regex, $str, $matches)){ 
var_dump($matches); 
} 
echo "n";

修饰符:用于转移正则表明式的表现。

作者们见到的('/^

孝敬代码:

$regex = '/HELLO/'; 
$str = 'hello word'; 
$matches = array(); 
if(preg_match($regex, $str, $matches)){ 
echo 'No i:Valid Successful!',"n"; 
} 
if(preg_match($regex.'i', $str, $matches)){ 
echo 'YES i:Valid Successful!',"n"; 
}

字符域:[w]用方括号扩起来的一对正是字符域。

限定符:如[w]{3,5}或者[w]*或者[w]+这些[w]后边的记号都表示节制符。现介绍具体意思。
{3,5}表示3到5个字符。{3,}超越3个字符,{,5}最多5个,{3}多个字符。
* 表示0到多个

  • 表示1到多个。
    脱字符号
    ^:
    > 放在字符域(如:[^w]卡塔尔(قطر‎中象征否定(不包含的乐趣卡塔尔国——“反向选择”
    > 放在表明式在此之前,表示以最近那一个字符开端。(/^n/i,表示以n最初卡塔尔(قطر‎。
    潜心,大家常常管""叫"跳脱字符"。用于转义一些特殊符号,如".","/"
    界符:正则表明式的方式常常如下:
    /love/
    此中坐落于“/”定界符之间的一对便是快要在指标对象中开展相称的方式。
    元字符:正是指这几个在正则表明式中具有优良意义的专项使用字符,能够用来鲜明其教导字符(即坐落于元字符前边的字符)在对象对象中的现身情势。
    相比常用的元字符蕴涵: “+”, “*”,以及 “?”。
    “+”元字符规定其指点字符必需在对象对象中连连现身三遍或频仍
    “*”元字符规定其指引字符必得在对象对象中冒出零次或再而三数12遍,
    “?”元字符规定其教导字符必得在指标对象中年老年是现身零次或二次。
    上边,就让大家来看一下正则表达式元字符的实际行使。
    /fo+/
    因为上述正则表达式中包罗“+”元字符(它前边的“o”是带领字符),表示能够与对象对象中的“fool”, “fo”等在字母f后边三回九转现身二个或四个字母o的字符串相相配。
    除了这些之外元字符之外,顾客还是可以够精确钦定情势在十分对象中冒出的效能。比方,
    /jim{2,6}/
    上述正则表明式规定字符m可以在格外对象中三翻五次现身2-6次,因而,上述正则表明式能够同jimmy或jimmmmmy等字符串相相称。
    其余多少个关键的元字符的利用办法。
    s:用于相配单个空格符,包含tab键和换行符;
    S:用于相配除单个空格符之外的享有字符;
    d:用于匹配从0到9的数字;
    w:用于匹配字母,数字或下划线字符;
    W:用于相称全部与w不相配的字符;
    . :用于匹配除换行符之外的享有字符。
    (表明:大家得以把s和S以致w和W看作互为逆运算)
    下边,大家就由此实例看一下怎么在正则表明式中运用上述元字符。
    /s+/
    上述正则表明式能够用来相配目的对象中的二个或五个空格字符。
    除去大家上述所介绍的元字符之外,正则表明式中还享有此外一种相比特殊的专项使用字符,即定位符。
    平素符:用于规定相称格局在对象对象中的现身岗位。
    较为常用的定势符包括: “^”, “$”, “b” 以至 “B”。
    “^”定位符规定相配形式必需出未来对象字符串的最早
    “$”定位符规定相配形式必得出今后对象对象的末段
    b定位符规定相配形式必需出今后对象字符串的起头或最终的三个边界之一
    “B”定位符则规定配成对象必得放在指标字符串的最早和结尾几个边界之内,即匹配对象既不可能看做靶子字符串的先河,也不能够同日而论对象字符串的尾声。同样,大家
    也得以把“^”和“$”以至“b”和“B”看作是互为逆运算的两组定位符。比世尊讲:
    /^hell/
    因为上述正则表明式中隐含“^”定位符,所以可以与对象对象中以 “hell”, “hello”或 “hellhound”初叶的字符串相匹配。
    /ar$/
    因为上述正则表明式中蕴藏“$”定位符,所以可以与对象对象中以 “car”, “bar”或 “ar” 结尾的字符串相相配。
    /bbom/
    因为上述正则表明式方式以“b”定位符开端,所以可以与目的对象中以 “bomb”, 或 “bom”在此以前的字符串相相配。
    /manb/
    因为上述正则表明式格局以“b”定位符结尾,所以能够与目的对象中以 “human”, “woman”或 “man”结尾的字符串相相称。
    为了能够有扶持顾客越来越灵敏的设定相称格局,正则表明式允许使用者在合营形式中钦定某四个范围而不囿于于实际的字符。比如:
    /[A-Z]/
    上述正则表明式将会与从A到Z范围内其余三个大写字母相相配。
    /[a-z]/
    上述正则表明式将会与从a到z范围内其他一个小写字母相匹配。
    /[0-9]/
    上述正则表明式将会与从0到9范围内任何二个数字相相称。
    /([a-z][A-Z][0-9])+/
    上述正则表明式将会与其余由字母和数字构成的字符串,如 “aB0” 等相相称。这里要求提示客商注意的少数正是足以在正则表明式中使用 “(State of Qatar” 把字符串组合在协同。
    “(卡塔尔”符号:富含的剧情必需同一时候出今后对象对象中。由此,上述正则表达式将不可能与诸如 “abc”等的字符串相称,因为“abc”中的最后一个字符为字母而非数字。
    设若大家期望在正则表明式中完成形似编程逻辑中的“或”运算,在五个例外的形式中任选一个進展相称的话,能够动用管道符: “|”。举个例子:
    /to|too|2/
    上述正则表明式将会与对象对象中的 “to”, “too”, 或 “2” 相相配。
    否定符:“[^]”。与大家前文所介绍的原则性符 “^” 不一样,否定符 “[^]”规定目的对象中不可能存在形式中所规定的字符串。举例:
    /[^A-C]/
    上述字符串将会与对象对象中除A,B,和C之外的此外字符相相称。经常的话,当“^”出以后“[]”内时就被视做否定运算符;而当“^”坐落于“[]”之外,或没有“[]”时,则应该被视做定位符。
    最后,当顾客须求在正则表达式的方式中投入元字符,并探究其配成对象时,能够行使
    转义符:“”。例如:
    /Th*/
    上述正则表达式将会与目的对象中的“Th*”而非“The”等相相称。
    实际上经验介绍
    要么得说说 ^ 和 $ 他们是分别用来相称字符串的开始和终止,以下分别比如表达:
    “^The”:发轫一定要有”The”字符串;
    “of despair$”:结尾必需求有”of despair” 的字符串;
    那么,
    “^abc$”:便是必要以abc开始和以abc结尾的字符串,实际上是独有abc相称;
    “notice”:相称包含notice的字符串;
    你可见假使您未曾用大家提到的多个字符(最终贰个例证),正是说形式(正则表明式)能够出今后被验证字符串的别样地点,你未曾把她锁定到两边。
    接着,说说 ‘*' ‘+' 和 ‘?'
    他俩用来表示七个字符能够现身的次数也许顺序,他们各自代表:
    “zero or more”相当于{0,}
    “one or more”相当于{1,}
    “zero or one.”相当于{0,1}
    此地是部分事例:
    “ab*”:和ab{0,}同义,相称以a初叶,后边能够接0个也许N个b组成的字符串(”a”, “ab”, “abbb”, 等卡塔尔;
    “ab+”:和ab{1,}同义,同上条相近,但起码要有二个b存在 (”ab” “abbb”等State of Qatar;
    “ab?”:和ab{0,1}同义,能够没有只怕独有叁个b;
    “a?b+$”:匹配以三个要么0个a再增添多个上述的b结尾的字符串。
    要点:'*' ‘+' 和 ‘?' 只管它前边那一个字符。
    您也能够在大括号里面节制字符现身的个数,譬喻:
    “ab{2}”: 须要a前面必然要跟四个b(一个也不能够少)(”abb”卡塔尔;
    “ab{2,}”: 必要a前边肯定要有几个或许七个以上b(如”abb” “abbbb” 等卡塔尔(قطر‎;
    “ab{3,5}”: 必要a后边能够有2-5个b(”abbb”, “abbbb”, or “abbbbb”State of Qatar。
    到现在我们把自然多少个字符放到小括号里,比方:
    “a(bc)*”: 相称 a 前面跟0个或许三个”bc”;
    “a(bc){1,5}”: 一个到5个 “bc”;
    再有一个字符 ‘|',也便是O途达操作:
    “hi|hello”: 相称含有”hi” 也许 “hello” 的 字符串;
    “(b|cd卡塔尔(قطر‎ef”: 相配含有 “bef” 或许 “cdef”的字符串;
    “(a|b)*c”: 匹配含有这么多个(包涵0个)a或b,前边跟叁个c的字符串;
    二个点('.'卡塔尔(قطر‎能够象征享有的单一字符,不包涵” ”
    若是,要协作满含” ”在内的兼具单个字符,如何做?
    用'[ .]'这种情势。
    “a.[0-9]”: 叁个a加二个字符再加一个0到9的数字;
    “^.{3}$”: 三个任性字符结尾。
    中括号括住的剧情只格外叁个单一的字符
    “[ab]”: 相称单个的 a 也许 b ( 和 “a│b” 相符State of Qatar;
    “[a-d]”: 相配'a' 到'd'的单个字符 (和”a│b│c│d” 还有“[abcd]”效果等同卡塔尔(قطر‎;
    平日大家都用[a-zA-Z]来钦定字符为二个高低写俄文:
    “^[a-zA-Z]”: 相称以大小写字母开端的字符串;
    “[0-9]%”: 匹配含有 形如 x% 的字符串;
    “,[a-zA-Z0-9]$”: 匹配以逗号再加一个数字或字母结尾的字符串;
    您也足以把你不想要得字符列在中括号里,你只供给在包蕴号内部使用'^' 作为开首 “%[^a-zA-Z]%” 相称含有多少个百分号里面有叁个非字母的字符串。
    要领:^用在中括号开始的时候,就意味着免除括号里的字符。
    为了PHP能够表明,你必须要在此些字符前面后加”,而且将部分字符转义。
    永不遗忘在中括号里面包车型客车字符是那条规路的比不上—在中括号里面,全体的特殊字符,蕴涵(”State of Qatar,都将失去他们的特出属性 “[*+?{}.]”相称含有那个字符的字符串:
    再有,正如regx的手册告诉大家:”固然列表里富含']',最佳把它作为列表里的首先个字符(恐怕跟在'^'后边卡塔尔。假若带有'-',最棒把它座落最前头恐怕最前面
    , or 大概贰个限量的首个结束点[a-d-0-9]中间的‘-'将有效。
    看了上边的事例,你对{n,m}应该知道了啊。要注意的是,n和m都无法为负整数,并且n总是小于m。这样,才能最少相配n次且最多相称m次。如”p{1,5}”将格外
    “pvpppppp”中的前八个p
    上面说说以起头的
    b 书上说他是用来同盟叁个单词边界,正是…比方'veb',能够相称love里的ve而不相称very里有ve
    B 无独有偶和方面包车型大巴b相反。
    正则表明式的别的用法
    领取字符串
    ereg(卡塔尔 and eregi(卡塔尔国有贰性格情是允许客户通过正则表明式去提取字符串的一有个别(具体用法你可以阅读手册卡塔尔国。譬如说,大家想从 path/UTiguanL 提取文件名,上面包车型客车代
    码正是你须要:
    ereg(”([^/]*)$”, $pathOrUrl, $regs);
    echo $regs[1];
    高档的转变
    ereg_replace() 和 eregi_replace(State of Qatar也是十分有效的,假设我们想把富有的间距负号都替换到逗号:
    ereg_replace(”[ t]+”, “,”, trim($str));
    以下为引用的开始和结果:

    preg_match()和preg_match_all() preg_quote() preg_split() preg_grep() preg_replace()

函数的切实运用,我们得以因此PHP手册来找到,下边共享部分平时积攒的正则表达式:
匹配action属性

以下为援引的剧情:

$str = ''; 
$match = ''; 
preg_match_all('/s+action="(?!http:)(.*?)"s/', $str, $match); 
print_r($match);

在正则中行使回调函数

以下为援用的从头到尾的经过:

/** 
* replace some string by callback function 
* 
*/ 
function callback_replace() { 
$url = 'http://esfang.house.sina.com.cn'; 
$str = ''; 
$str = preg_replace ( '/(?<=saction=")(?!http:)(.*?)(?="s)/e', 'search($url, 1)', $str ); 
echo $str; 
} 
function search($url, $match){ 
return $url . '/' . $match; 
}

带断言的正则相称

$match = ''; 
$str = 'xxxxxx.com.cn bold font 
paragraph text 
'; 
preg_match_all ( '/(?<=<(w{1})>).*(?=</1>)/', $str, $match ); 
echo "匹配没有属性的HTML标签中的内容:"; 
print_r ( $match );

更动HTML源码中的地址

以下为引用的内容:

$form_html = preg_replace ( '/(?<=saction="|ssrc="|shref=")(?!http:|javascript)(.*?)(?="s)/e', 'add_url($url, '1')', $form_html );

元字符

在地点的事例中,^ 、d 及 $ 等那么些标识,代表了特定的配心仪义,大家誉为元字符,常用的元字符如下:
元字符 说明
. 匹配除换行符意外的人身自由字符
w 相配字母或数字或下划线
s 相称任性的空白符
d 相配数字
b 般配单词的开首或终止
^ 相称字符串的发端
$ 相称字符串的收尾
[x] 相称x字符,如相称字符串中的 a、b 和 c 字符
W w的反义,即相配任性非字母,数字,下划线和汉字的字符
S s的反义,即匹配率性非空白符的字符
D d的反义,即相配放肆非数字的字符
B b的反义,即不是单词开始或收尾的地点
[^x] 相配除了 x 意外的轻松字符,如 [^abc] 相配除了 abc 那多少个假名之外的人身自由字符

下一篇:没有了