资讯专栏INFORMATION COLUMN

正则表达式

whataa / 476人阅读

摘要:元字符指在正则表达式中有特殊含义的字符包括定界符定位符限定符转义符选择符等。其中是非捕获元字符之一,还有两个非捕获元字符是和正向预查,在任何匹配的字符串开始处匹配查找字符串。

定义
是一组描述字符串特征的字符
作用
用来检查一个串是否含有某种子串、将匹配的子串做替换或者从某个串中取出符合某个条件的子串等
语法

使用斜杠作为定界符,如 /[-a-z]/。正则表达式分为普通字符和元字符,普通字符分为打印字符和非打印字符,打印字符包括字母字符、数字、标点及一些其他符号,非打印字符指打印到纸张上后不可见的字符,包括空格符、回车符、制表符、垂直制表符、换行符、换页符等。元字符指在正则表达式中有特殊含义的字符包括定界符、定位符、限定符、转义符、选择符等。
限定符用来限定元素出现的次数,有 ? + * {n} {n,} {n,m} 共6种。限定符的默认模式是贪婪模式,贪婪模式会尽可能多的匹配字符,在它们的后面加上一个?就会变成非贪婪模式,非贪婪模式会尽可能少的匹配字符,如

$subject="< a1>expressions< a1>";
$pattern="/<.*>/";
$res=preg_match_all($pattern, $subject,$matches);
echo $matches[0][0];//结果为  < a1>expressions< a1>
$res=preg_match_all("/<.*?>/", $subject,$matches);
echo $matches[0][0];//结果为  < a1>
定位符

用来描述字符串或单词的边界,也就是指单词和空格间的位置,^和$分别指字符串的开始与结束,描述单词的前或后边界,B表示非单词边界。不能对定位符使用限定符。例如, "er" 可以匹配"a never aa" 中的 "er",但不能匹配 "a verb" 中的 "er"。"erB" 能匹配 "verb" 中的 "er",但不能匹配 "never" 中的 "er"。

选择符

圆括号用来使被括起来的部分最为一个整体存在,可以用限定符修饰,如 (aa)* ,同时被括起来的部分也会成为一个子表达式被缓存起来用于后面的引用,如 (aa)b1可以匹配 aabaa或aabaac,另外引用时最大只能到99,意思就是缓冲区最多只能放99个子表达式,如果不需要进行引用则可以用?:禁用缓存,如 "industr(?:y|ies) 就是一个比 "industry|industries" 更简略的表达式 。其中?:是非捕获元字符之一,还有两个非捕获元字符是?=和?!
(?=pattern) 正向预查,在任何匹配 pattern 的字符串开始处匹配查找字符串。这是一个非获取匹配,也就是说,该匹配不需要获取供以后使用。例如,"Windows (?=95|98|NT|2000)" 能匹配 "Windows 2000" 中的 "Windows" ,但不能匹配 "Windows 3.1" 中的 "Windows"。预查不消耗字符,也就是说,在一个匹配发生后,在最后一次匹配之后立即开始下一次匹配的搜索,而不是从包含预查的字符之后开始;
(?!pattern) 负向预查,在任何不匹配 pattern 的字符串开始处匹配查找字符串。这是一个非获取匹配,也就是说,该匹配不需要获取供以后使用。例如"Windows (?!95|98|NT|2000)" 能匹配 "Windows 3.1" 中的 "Windows",但不能匹配 "Windows 2000" 中的 "Windows"。预查不消耗字符,也就是说,在一个匹配发生后,在最后一次匹配之后立即开始下一次匹配的搜索,而不是从包含预查的字符之后开始

操作符的运算优先级

由高到低依次为 转义符、圆括号和方括号、限定符、定位符和普通字符、"或"操作符,如,普通字符具有高于替换运算符的优先级,使得"m|food"匹配"m"或"food"。若要匹配"mood"或"food",请使用括号创建子表达式,即"(m|f)ood"

PHP中和正则表达式相关的函数

preg_quote - 转义正则表达式字符
preg_match — 执行正则表达式
preg_match_all - 执行一个全局正则表达式
preg_replace - 执行一个正则表达式并替换匹配内容
preg_​filter 等价于preg_replace() 除了它仅仅返回(可能经过转化)与目标匹配的结果
preg_replace_callback - 执行一个正则表达式搜索并且使用一个回调进行替换
preg_replace_callback_array - 执行一个正则表达式搜索并且使用一个回调进行替换
preg_split - 通过一个正则表达式分隔字符串
preg_last_error - 返回最后一个PCRE正则执行产生的错误代码
preg_​grep 返回给定数组input中与模式pattern匹配的元素组成的数组
strpos - 仅检查某个字符串是否包含另外一个字符串

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/28454.html

相关文章

  • 正则达式

    摘要:本文内容共正则表达式火拼系列正则表达式回溯法原理学习正则表达式,是需要懂点儿匹配原理的。正则表达式迷你书问世了让帮你生成和解析参数字符串最全正则表达式总结验证号手机号中文邮编身份证地址等是正则表达式的缩写,作用是对字符串执行模式匹配。 JS 的正则表达式 正则表达式 一种几乎可以在所有的程序设计语言里和所有的计算机平台上使用的文字处理工具。它可以用来查找特定的信息(搜索),也可以用来查...

    bang590 评论0 收藏0
  • JS中的正则达式

    摘要:构造函数可以有两个字符串参数,第一个参数包含正则表达式的主体部分。只读的布尔值,说明这个正则表达式是否带有修饰符。中正则的扩展构造函数在中,只能接受字符串作为参数,允许其直接接受正则表达式作为参数。 上文传送门:初探正则表达式 正则表达式是一个描述字符模式的对象,JavaScript 的 RegExp 类表示正则表达式,String 和 RegExp 都定义了方法,后者使用正则表达式进...

    Soarkey 评论0 收藏0
  • JavaScript正则达式总结

    摘要:正则表达式一直是里比较难以掌握的点。在中创建正则的两种方式使用字面量这就是正则表达式的字面量语法,表示正则表达式的模式,为正则表达式的标志。字面量形式的正则表达式一般使用较多,也推荐大家尽可能使用这种形式,简洁易读,符合正常的使用习惯。 正则表达式一直是js里比较难以掌握的点。 看不懂,学不会,记不住。 每次需要用到正则的时候,都需要再去查找资料。 今天花时间把正则的知识点总结下,希望...

    big_cat 评论0 收藏0
  • 正则与JS中的正则

    摘要:注意本文将正则与中的正则分开讨论。正则零宽断言更多参考各种语言对于正则不同支持参考单行模式与多行模式通过设置正则表达式后的修饰符可开启对应的匹配模式单行模式和多行模式。 最近这段时间帮同学处理一些文档, 涉及到一些结构化文档的工作大部分都得使用正则表达式, 之前对于正则的认识大多来源于语言书上那几页的介绍, 自己也没有用过几次。这里将我之前感到模糊的概念作个整理。因为对JS了解多点,所...

    firim 评论0 收藏0
  • JavaScript正则达式的匹配模式

    摘要:选择分组和引用正则表达式的语法还包括指定选择项子表达式分组和引用前一子表达式的特殊字符。带圆括号的表达式的另一个用途是允许在同一正则表达式的后部引用前面的子表达式。 正则表达式(regular expression)是一个描述字符模式的对象。JavaScript的 RegExp类 表示正则表达式,String和RegExp都定义了方法,后者使用正则表达式进 行强大的模式匹配和文本检索与...

    wqj97 评论0 收藏0
  • 正则达式

    摘要:最全正则表达式总结验证号手机号中文邮编身份证地址等是正则表达式的缩写,作用是对字符串执行模式匹配。学习目标了解正则表达式语法在中使用正则表达式在中使 JS高级技巧 本篇是看的《JS高级程序设计》第23章《高级技巧》做的读书分享。本篇按照书里的思路根据自己的理解和经验,进行扩展延伸,同时指出书里的一些问题。将会讨论安全的类型检测、惰性载入函数、冻结对象、定时器等话题。1. 安全的类型检测...

    yibinnn 评论0 收藏0

发表评论

0条评论

whataa

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<