PHP ノート 3

WBOY
WBOYオリジナル
2016-06-23 13:33:35778ブラウズ

<?php	#正则表达式	#就是一种描述字符串结构的语法规则	#是一个特定的格式化模式        #1. 行定位符    /*	1) ^行首	2)$行尾		tm eqaul Tomorrow Moon		^tm 匹配		tm$不匹配		tm屁匹配任意位置    */	#2. 单词界定符	/*	1)b \btm\b表示要查找一个完整的单词	2)B \Btm|b正好相反 表示查找的不是一个完整的单词	*/	#3. 字符类	/*	1)正则表达式是区分大小写的如果要想忽略大小写可以使用[]	  但是一个[]只能包含一个字符 例如tm的匹配要写成[tT][mM]	2)POSIX预定义的字符类		[:digit:]    [0-9]		[[:alnum:]]  字母数字集合		[[:alpha:]]  字母集合		[[:blank:]]  空格 水平制表		[[:xdigit:]] 十六进制数字		[[:punct:]]  特殊字符 !@#$%^&*?		[[:print:]]  所有可打印字符(包括空白字符)		[[:space:]]  空包字符 空格 换行 换页 回车 水平制表		[[:graph:]]  所有可打印字符(不包括空白字符)		[[:upper:]]  大写字母		[[:lower:]]  小写字母		[[:cntrl:]]  控制字符	*/	#4 选择字符 |	/*	可以理解为或的意思	*/	#5 连接字符 _	/*	[a,b,d...,z] ==> [a-z]	*/	# 排除字符 [^]	# [^a-zA-Z] 除了字符以外的	#6 限定符 (?*+{n,m})	/*	? 匹配前面的字符零次或者一次 colo?r可以匹配colour color	+ 匹配前面的字符一次或多次   go+gle可以匹配google到go...ogle	* 匹配前面的字符零次或多次   go*gle可以匹配ggle到go...ogle	{n} 匹配前面的字符n次	{n,} 匹配前面的字符至少n次	{n,m} 匹配前面的字符至少n次 至多m次	*/    #7 点号字符	/*	能够表示出了换行符以外的任意一个字符	比如匹配首字母是S尾字母是T的三个字母的单词	^s.t$	*/	#8 转义字符	/*	同c java中的一致	*/	#9 反斜线(\)	/*	反斜线定义了一些不可显示 比如 \b 退格键 \n换行等等	*/	#10 小括号	/*	改变限定符的作用域	*/	#11 反向引用	/*	反向引用就是一考表达式的记忆功能匹配连续出现的字符串或字母	如匹配连续两个it 首先将单词it作为分组 然后在后面加上"\1"即可 格式为:	(it)\1 //其中这个1代表的分组的序号 因为可能有多个分组	*/	#12 模式修饰符	/*	i 忽略大小写	m 多文本形式 字串中含有多个换行符 影响^$的匹配	s 单文本形式 .可以匹配$^	x 忽略空白字符      修饰符有三种格式:(?i)tm(?-i),(?i:tm),/tm/i	*/    #php中POSIX扩展正则表达式函数    /*	bool erge/eregi(string pattern, string string[, array regs])	在string中查找pattern,如果存在第三个参数,则会将匹配的字串划分	存到数组中去 第一个区分大小写 第二个不区分    */	/*	bool ereg_replace/eregi_replace(string pattern, string replacement, string string)	在字符串string中匹配pattern,如果成果使用replacement替换 并且返回替换后的string	第一个区分大小写 第二种不	*/	/*	array split/split(string pattern, string string[, int limit])	使用pattern分割字符串string 存在参数limit的话就是限制分割的个数	*/	#PCER兼容正则表达式函数	/*	array preg_grep(string pattern, array input)函数	使用input一一匹配表达式pattern 最后返回所有	由所有匹配成功的元素组成的数组	*/    $input = array('helloJimbo','nihaoaJinbo');    $pattern = '/J...o/';    $arr = preg_grep($pattern, $input);    //echo sizeof($arr);    for($i = 0; $i < sizeof($arr); $i++){    	echo "$arr[$i]<br>";    }    /*    int preg_match/preg_match_all(string pattern, string subject[, array matches])    在字符串subject中匹配表达式pattern    函数返回匹配次数,如果有matches,    */    /*    string preg_quote(string str[, string delimiter])    将str里面的所有特殊字符自动转义    如果有delimiter参数 则delimiter里面的字符也被转义	    */    /*    preg_replace(mixed pattern, mixed replacement, mixed subject[, int limit])    在subject中匹配pattern,匹配到替换成replacement,有limit限制次数    preg_replace_callback(mixed pattern, callback callback, mixed subject[, int limit])    功能相同 只不过replacement换成回调函数 可以更灵活	    */    /*	array preg_split(string pattern, string subject[, int limit])	分割字符串    */?>

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。