对于正则表达式一直不是很擅长,因此有必要记录一下。html

正则表达式的基本知识

行定位符(^与$)正则表达式

行定位符是用来描述字符串的边界。“$”表示行结尾“^”表示行开始如"^de",表示以de开头的字符串 "de$",表示以de结尾的字符串。.net

单词定界符code

咱们在查找的一个单词的时候,如an是否在一个字符串”gril and body”中存在,很明显若是匹配的话,an确定是能够匹配字符串“gril and body”匹配到,怎样才能让其匹配单词,而不是单词的一部分呢?这时候,咱们能够是哟个单词定界符b。

banb 去匹配”gril and body”的话,就会提示匹配不到。

固然还有一个大写的B,它的意思,和b正好相反,它匹配的字符串不能使一个完整的单词,而是其余单词或字符串中的一部分。如BanB。htm

选择字符(|) ,表示或对象

选择字符表示或的意思。如Aa|aA,表示Aa或者是aA的意思。注意使用”[]”与”|”的区别,在于”[]”只能匹配单个字符,而”|”能够匹配任意长度的字符串。在使用”[]”的时候,每每配合链接字符”-“一块儿使用,如[a-d],表明a或b或c或d。blog

排除字符,排除操做utf-8

正则表达式提供了”^”来表示排除不符合的字符,^通常放在[]中。如unicode

限定符(?*+{n,m})字符串

限定符主要是用来限定每一个字符串出现的次数。

限定字符

含义

零次或一次

*

零次或屡次

+

一次或屡次

{n}

n次

{n,}

至少n次

{n,m}

n到m次

/x表示16进制

/u 表示按unicode(utf-8)匹配(主要针对多字节好比汉字)

/i 表示不区分大小写(若是表达式里面有 a, 那么 A 也是匹配对象)

/s 表示将字符串视为单行来匹配

必须只有中英文和数字

$match = "/^[\x{4e00}-\x{9fa5}A-Za-z0-9]+$/u";

if(!preg_match($match,$title)){

echo "含有中文,英文,数字之外的字符";

}else{

echo "只有中文,英文,数字之外的字符";

}

只需包含中英文和数字

$match = "/[\x{4e00}-\x{9fa5}A-Za-z0-9]/u";

if(!preg_match($match,$title)){

echo "不含有中文,英文,数字字符";

}else{

echo "含有中文,英文,数字字符";

}

1-5 ↩

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐