最全的正则表达式整理

简介: 最全的正则表达式整理
  1. 定界符


表达式的格式: “/表达式/[修正符]”

解释:

其中"/"表示正则表达式的定界符,但是也可以是其他符号:如”#“,”!“

注意:定界符不可以是字母、数字和斜线\。 像“#”、“|”、“!”等都可以的 如:/…/ #…# |…|

其中修正符是可选的,表示对表达式做额外的修饰。


  1. 模式修正符
修饰符 说明
i 忽略大小写
m 多文本模式
s 单行文本模式
x 忽略空白字符
U 表示拒绝贪婪匹配
g 表示全局匹配

解释:

g: 如果不带g,正则过程中字符串从左到右匹配,找到第一个符合条件的即匹配成功,返回

如果带g,则字符串从左到右,找到每个符合条件的都记录下来,直到字符串结尾位置


  1. 行定位符(^与$)

行定位符是用来描述字符串的边界

“$”表示行结尾,“^”表示行开始,

如"^de",表示以de开头的字符串

“de$”,表示以de结尾的字符串。


  1. 单词定界符

\b让其匹配单词,而不是单词一部分.

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

大写的\B,和\b正好相反,它匹配的字符串不能是一个完整的单词,而是其他单词或字符串中的一部分

如\Ban\B


  1. 选择字符 | ,表示或


选择字符表示或的意思。如Aa|aA,表示Aa或者是aA的意思。

注意使用”[]”与”|”的区别,在于”[]”只能匹配单个字符,而”|”可以匹配任意长度的字符串。

在使用”[]”的时候,往往配合连接字符”-“一起使用,

如[a-d],代表a或b或c或d。


  1. ^ 排除字符,排除操作

正则表达式提供了”^”来表示排除不符合的字符

^ 一般放在[]中。如 [^1-5] ,该字符不是1~5之间的数字。


  1. 限定符(?*+{n,m}.)

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

限定字符 含义
零次或一次
* 零次或多次
+ 一次或多次
零次或一次
{n} n次
{n,} 至少n次
{n,m} n到m次
. 匹配任意一个字符(不包含换行符)
如(D+)表示一个或多个D


  1. 转义字符\

转义字符主要是将一些特殊字符转为普通字符。而这些常用特殊字符有”.”,”?”、”\”等。

  1. 指定预定义的字符集
字符 含义
\d 任意一个十进制数字[0-9]
\D 任意一个非十进制数字
\s 任意一个空白字符(空格、换行符、换页符、回车符、字表符)
\S 任意一个非空白字符
\w 任意一个单词字符
\W 任意个非单词字符


  1. 显示不可打印的字符
字符 含义
\a 报警
\b 退格
\f 换页
\n 换行
\r 回车
\t 字表符


  1. 括号字符()

改变限定符如(|、* 、^)的作用范围

如(my|your)baby,如果没有”()”,将匹配的是要么是my,要么是yourbaby,

有了小括号,匹配的就是mybaby或yourbaby。


  1. php中贪婪匹配与惰性匹配


贪婪匹配:就是匹配尽可能多的字符。

比如,正则表达式中m.n,它将匹配最长以m开始,n结尾的字符串。如果用它来搜索manmpndegenc的话,它将匹配到的字符串是manmpndegen而非man。可以这样想,当匹配到m的时候,它将从后面往前匹配字符n。

懒惰匹配:就是匹配尽可能少的字符。
有的时候,我们需要并不是去贪婪匹配,而是尽可能少的去匹配。这时候,就需要将其转为惰性匹配。怎样将一个贪婪匹配转为惰性匹配呢?只需要在其后面添加一个”?”即可。如m.?n将匹配manmpndegenc,匹配到的字符串是man。

函数符 描述
*? 零次或多次,但尽可能少的匹配
+? 一次或多次,但尽可能少的匹配
?? 0次或1次,但尽可能少的匹配
{n,}? 至少n次,但尽可能少的匹配
{n,m}? n到m次 ,但尽可能少的匹配


常用正则表达式


汉字:/^[\u4e00-\u9fa5]{0,}$/
数字:/^[0-9]*$/
Email地址:/^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/
域名:/[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(/.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+/.?/
InternetURL:/[a-zA-z]+://[^\s]* 或 ^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$/
手机号码:/^1[3458]\d{9}/
电话号码(“XXX-XXXXXXX”、”XXXX-XXXXXXXX”、”XXX-XXXXXXX”、”XXX-XXXXXXXX”、”XXXXXXX”和”XXXXXXXX):
    /^($$\d{3,4}-)|\d{3.4}-)?\d{7,8}$/
国内电话号码(0511-4405222、021-87888822):/\d{3}-\d{8}|\d{4}-\d{7}/
身份证号(15位、18位数字):^\d{15}|\d{18}$ 短身份证号码(数字、字母x结尾):
    /^([0-9]){7,18}(x|X)?$/ 或 /^\d{8,18}|[0-9x]{8,18}|[0-9X]{8,18}?$/
帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):/^[a-zA-Z][a-zA-Z0-9_]{4,15}$/
密码(以字母开头,长度在6~18之间,只能包含字母、数字和下划线):/^[a-zA-Z]\w{5,17}$/


正则表达式在php中应用


//一个正则表达式验证,返回0或1
preg_match('正则表达式', $string);
//一个正则表达式匹配,返回匹配成功个数,$result返回匹配成功内容
preg_match('正则表达式', $string, $result);

例子:

//U禁止贪婪匹配
$userinfo = "Name: <b>PHP</b> <br> Title: <b>Programming Language</b>";
preg_match("/<b>(.*)<\/b>/U", $userinfo, $pat_array);
print_r($pat_array);

结果:


完毕


好了,我是向宇,https://xiangyu.blog.csdn.net/

目录
相关文章
|
6月前
常用正则表达式汇总整理
常用正则表达式汇总整理
44 0
|
6月前
|
数据采集 自然语言处理 监控
正则表达式相关知识点
正则表达式相关知识点
62 0
|
6月前
|
JavaScript 前端开发 数据库
正则表达式[进阶]
正则表达式[进阶]
60 0
|
程序员
常用正则表达式整理【总结】
平时不太喜欢记忆这些东西,开发的时候需要拿过来直接用就好
119 0
|
XML 前端开发 Java
常用正则表达式整理
常用正则表达式整理
279 0
|
机器学习/深度学习 自然语言处理 PHP
正则表达式知识点整理
正则表达式(Regular Expression)就是用某种模式去匹配一类字符串的一种公式。 正则表达式使用单个字符串来描述、匹配一系列匹配某个句法规则的字符串。 正则表达式是繁琐的,但它是强大的,学会之后的应用会让你除了提高效率外,会给你带来绝对的成就感。只要认真阅读本教程,加上应用的时候进行一定的参考,掌握正则表达式不是问题。
帮你读懂正则表达式
什么是正则表达式?通过正则表达式创建2种方式、正则表达式的组成剖析、几个例子分析来帮你读懂常见正则表达式。
|
机器学习/深度学习 移动开发 JavaScript
正则表达式学习记录
正则表达式学习记录
213 0
基本正则笔记
1.   ^   字符串的开始; $ 字符串的结束  example: "^abc" 以abc 开头   "def$"  以def结尾 2.  *   没有或者更多; + 一次或者更多  ; ? 没有或者一个  example:  "ab*" a 后面跟着零个或者若干个b;       "ab+" ...
1081 0