`
purpen
  • 浏览: 796730 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

posix和perl标准的正则表达式区别

阅读更多

正则表达式(Regular Expression,缩写为regexp,regex或regxp),又称正规表达式、正规表示式或常规表达式或正规化表示法或正规表示法,是指一个用来描述或者匹配一系列符合某个句法规则的字符串的单个字符串 。在很多文本编辑器或其他工具里,正则表达式通常被用来检索和/或替换那些符合某个模式的文本内容 。许多程序设计语言都支持利用正则表达式进行字符串操作。例如,在Perl中就内建了一个功能强大的在正则表达式引擎。正则表达式这个概念最初是由 Unix中的工具软件(例如sed和grep)普及开的。(摘自维基百科)

PHP同时使用两套正则表达式规则,一套是由电气和电子工程师协会(IEEE)制定的POSIX Extended 1003.2兼容正则(事实上PHP对此标准的支持并不完善),另一套来自PCRE(Perl Compatible Regular Expression)库提供PERL兼容正则,这是个开放源代码的软件,作者为 Philip Hazel。

使用POSIX兼容规则的函数有:
ereg_replace()
ereg()
eregi()
eregi_replace()
split()
spliti()
sql_regcase()
mb_ereg_match()
mb_ereg_replace()
mb_ereg_search_getpos()
mb_ereg_search_getregs()
mb_ereg_search_init()
mb_ereg_search_pos()
mb_ereg_search_regs()
mb_ereg_search_setpos()
mb_ereg_search()
mb_ereg()
mb_eregi_replace()
mb_eregi()
mb_regex_encoding()
mb_regex_set_options()
mb_split()

使用PERL兼容规则的函数有:
preg_grep()
preg_replace_callback()
preg_match_all()
preg_match()
preg_quote()
preg_split()
preg_replace()

定界符:

POSIX兼容正则没有定界符,函数的相应参数会被认为是正则。

PERL兼容正则可以使用任何不是字母、数字或反斜线(\)的字符作为定界符,如果作为定界符的字符必须被用在表达式本身中,则需要用反斜线转义。也可以使用(),{},[] 和 <> 作为定界符

修正符:

POSIX兼容正则没有修正符。

PERL兼容正则中可能使用的修正符(修正符中的空格和换行被忽略,其它字符会导致错误):

i (PCRE_CASELESS):
匹配时忽略大小写。

m(PCRE_MULTILINE):
当设定了此修正符,行起始(^)和行结束($)除了匹配整个字符串开头和结束外,还分别匹配其中的换行符(\n)的之后和之前。

s(PCRE_DOTALL):
如果设定了此修正符,模式中的圆点元字符(.)匹配所有的字符,包括换行符。没有此设定的话,则不包括换行符。

x(PCRE_EXTENDED):
如果设定了此修正符,模式中的空白字符除了被转义的或在字符类中的以外完全被忽略。

e:
如果设定了此修正符,preg_replace() 在替换字符串中对逆向引用作正常的替换,将其作为 PHP 代码求值,并用其结果来替换所搜索的字符串。 只有 preg_replace() 使用此修正符,其它 PCRE 函数将忽略之。

A(PCRE_ANCHORED):
如果设定了此修正符,模式被强制为“anchored”,即强制仅从目标字符串的开头开始匹配。

D(PCRE_DOLLAR_ENDONLY):
如果设定了此修正符,模式中的行结束($)仅匹配目标字符串的结尾。没有此选项时,如果最后一个字符是换行符的话,也会被匹配在里面。如果设定了 m 修正符则忽略此选项。

S:
当一个模式将被使用若干次时,为加速匹配起见值得先对其进行分析。如果设定了此修正符则会进行额外的分析。目前,分析一个模式仅对没有单一固定起始字符的 non-anchored 模式有用。

U(PCRE_UNGREEDY):
使“?”的默认匹配成为贪婪状态的。

X(PCRE_EXTRA):
模式中的任何反斜线后面跟上一个没有特殊意义的字母导致一个错误,从而保留此组合以备将来扩充。默认情况下,一个反斜线后面跟一个没有特殊意义的字母被当成该字母本身。

u(PCRE_UTF8):
模式字符串被当成UTF-8。

逻辑区隔:

POSIX兼容正则和PERL兼容正则的逻辑区隔符号作用和使用方法完全一致:
[]:包含任选一操作的相关信息。
{}:包含匹配次数的相关信息。
():包含一个逻辑区间的相关信息,可被用来进行引用操作。
|:表示“或”,[ab]和a|b是等价的。

元字符与“[]”相关:

有两组不同的元字符:一种是模式中除了方括号内都能被识别的,还有一种是在方括号“[]”内被识别的。

POSIX兼容正则和PERL兼容正则“[]之外”“一致”的元字符:
\ 有数种用途的通用转义符
^ 匹配字符串的开头
$ 匹配字符串的结尾
? 匹配0或者1
* 匹配 0 个或多个前面指定类型的字符
+ 匹配 1 个或多个前面指定类型的字符

POSIX兼容正则和PERL兼容正则“[]之外”“不一致”的元字符:
. PERL兼容正则匹配除了换行符外的任意一个字符
. POSIX兼容正则匹配任意一个字符

POSIX兼容正则和PERL兼容正则“[]之内”“一致”的元字符:
\ 有数种用途的通用转义符
^ 取反字符,但仅当其为第一个字符时有效
- 指定字符ASCII范围,仔细研究ASCII码,你会发现[W-c]等价于[WXYZ\\^_`abc]

POSIX兼容正则和PERL兼容正则“[]之内”“不一致”的元字符:
- POSIX兼容正则中[a-c-e]的指定会抛出错误。
- PERL兼容正则中[a-c-e]的指定等价于[a-e]。

匹配次数与“{}”相关:

POSIX兼容正则和PERL兼容正则在匹配次数方面完全一致:
{2}:表示匹配前面的字符2次
{2,}:表示匹配前面的字符2次或多次,默认都是贪婪(尽可能多)的匹配
{2,4}:表示匹配前面的字符2次或4次

逻辑区间与“()”相关:

使用()包含起来的区域是一个逻辑区间,逻辑区间的主要作用是体现出一些字符出现的逻辑次序,另一个用处就是可以用来引用(可以将此区间内的值引用给一个变量)。后一个作用比较奇特:
<?php
$str = "http://www.163.com/";
// POSIX兼容正则:
echo ereg_replace("(.+)","<a href = \\1 >\\1</a>",$str);
// PERL兼容正则:
echo preg_replace("/(.+)/","<a href = $1 >$1</a>",$str);
// 显示两个链接
?>

在引用的时候,括号是可以嵌套的,逻辑次序是按照“(”出现的次序来标定的。

类型匹配:

POSIX兼容正则:
[:upper:]:匹配所有的大写字母
[:lower:]:匹配所有的小写字母
[:alpha:]:匹配所有的字母
[:alnum:]:匹配所有的字母和数字
[:digit:]:匹配所有的数字
[:xdigit:]:匹配所有的十六进制字符,等价于[0-9A-Fa-f]
[:punct:]:匹配所有的标点符号,等价于 [.,"'?!;:]
[:blank:]:匹配空格和TAB,等价于[ \t]
[:space:]:匹配所有的空白字符,等价于[ \t\n\r\f\v]
[:cntrl:]:匹配所有ASCII 0到31之间的控制符。
[:graph:]:匹配所有的可打印字符,等价于:[^ \t\n\r\f\v]
[:print:]:匹配所有的可打印字符和空格,等价于:[^\t\n\r\f\v]
[.c.]:功能不明
[=c=]:功能不明
[:<:]:匹配单词的开始
[:>:]:匹配单词的结尾

PERL兼容正则(这里可以看出PERL正则的强大):
\a alarm,即 BEL 字符(’0)
\cx "control-x",其中 x 是任意字符
\e escape(’0B)
\f 换页符 formfeed(’0C)
\n 换行符 newline(’0A)
\r 回车符 carriage return(’0D)
\t 制表符 tab(’0)
\xhh 十六进制代码为 hh 的字符
\ddd 八进制代码为 ddd 的字符,或 backreference
\d 任一十进制数字
\D 任一非十进制数的字符
\s 任一空白字符
\S 任一非空白字符
\w 任一“字”的字符
\W 任一“非字”的字符
\b 字分界线
\B 非字分界线
\A 目标的开头(独立于多行模式)
\Z 目标的结尾或位于结尾的换行符前(独立于多行模式)
\z 目标的结尾(独立于多行模式)
\G 目标中的第一个匹配位置

分享到:
评论

相关推荐

    解析posix与perl标准的正则表达式区别

    POSIX和Perl两种标准是正则表达式的两种常见实现方式,它们各有特点和用途。 首先,POSIX正则表达式是基于IEEE POSIX标准的一个变体,它主要被用于Unix和类Unix系统中的文本处理工具,如sed和grep等。POSIX正则...

    Oracle数据库正则表达式

    从 Oracle 10g 开始,Oracle 内建了符合 IEEE POSIX (Portable Operating System for Unix)标准的正则表达式,同时也支持 Perl 的正则表达式规则。 正则表达式的组成 ----------------- 正则表达式由一个或多个...

    关于正则表达式的应用(正则表达式)

    在实际应用中,正则表达式可以用于验证电子邮件地址、URL、电话号码格式,从长文本中提取特定信息,或者清洗和标准化数据。其灵活性和强大功能使得它成为许多开发者不可或缺的工具。为了更好地掌握正则表达式,建议...

    php正则表达式.txt

    2. **POSIX标准的正则表达式**:这种正则表达式较为简单,主要用于基本的匹配需求。在PHP中,`ereg_*`系列函数是基于POSIX风格的正则表达式,但其功能相比Perl5风格的正则表达式要有限得多。 ### PHP正则表达式函数...

    精通正则表达式(第三版)中文

    本章深入探讨了不同模式语法的特点,如POSIX、Perl兼容正则表达式(PCRE)等,并对比了它们之间的差异。 #### 第二部分:应用篇 - **第4章:搜索与替换** 讲解如何使用正则表达式进行高效的搜索和替换操作。 - **...

    正则表达式 电子书 教程 chm

    在不同编程语言中,正则表达式的实现可能会有差异,但大多数都遵循Perl风格或POSIX标准。例如,Python的`re`模块和JavaScript的`RegExp`对象提供了丰富的功能,支持正则表达式的编译、执行和调试。 CHM(Compiled ...

    精通正则表达式

    - **第4章至第7章**:分别针对Perl、PCRE(Perl兼容正则表达式)、POSIX BRE/ERE以及.NET框架下的正则表达式进行了深入分析,包括各自的特点、语法差异以及实际应用案例。 - **第8章:扩展功能**:讨论了一些高级...

    php正则表达式

    PHP支持两种类型的正则表达式:Perl兼容正则表达式(PCRE)和POSIX兼容正则表达式。 1. **Perl兼容正则表达式 (PCRE)** - PCRE是PHP中最常用的正则表达式形式,功能强大且灵活。 - 主要函数包括`preg_match`、`...

    正则表达式AndMySQL参考文档chm

    例如,MySQL的`REGEXP`使用的是Perl兼容的正则表达式(PCRE),而某些其他数据库系统可能使用POSIX标准。理解这些差异对于编写跨平台的代码至关重要。 总之,正则表达式和MySQL都是IT专业人士不可或缺的工具。熟练...

    PHP和正则表达式的关系

    PHP提供了两种主要的正则表达式处理方式:Perl兼容正则表达式(PCRE)和POSIX标准兼容正则表达式。在本文中,我们将主要探讨POSIX标准的正则表达式函数,如`ereg`系列。 1. **PHP 和正则表达式**:PHP内置了对正则...

    正则表达式入门30分钟

    虽然原生支持并不像其他某些语言(如Perl或JavaScript)那么直接,但通过库函数如POSIX标准的`regcomp`和`regexec`,或是PCRE(Perl Compatible Regular Expressions)库,我们可以有效地利用正则表达式功能。...

    精通正则表达式~~~

    第3章:正则表达式的特性和流派概览.... 83 在正则的世界中漫步... 85 正则表达式的起源... 85 最初印象... 91 正则表达式的注意事项和处理方式... 93 集成式处理... 94 程序式处理和面向对象式处理... 95 ...

    java正则表达式详解(PDF)

    它是基于Perl和POSIX正则表达式的实现,提供了一种灵活且强大的方式来处理文本数据。本文件"java正则表达式详解(PDF)"深入探讨了这一主题,下面将对其中的主要知识点进行详细介绍。 1. **正则表达式基本概念** -...

    正则表达式参考手册(英文)

    此外,PHP 还提供了 POSIX 风格的正则表达式支持,但通常不推荐使用,因为它们在功能和性能上并不比 Perl 风格的正则表达式更有优势。 - **匹配引擎**:`preg` 系列函数使用的是传统的非确定性有限自动机 (NFA) ...

    shell正则表达式.txt

    ### Shell正则表达式...总结而言,正则表达式是Shell脚本和文本处理中的强大工具,理解并熟练掌握其语法和特性对于提高工作效率非常关键。通过不断实践和探索,我们可以更灵活地使用正则表达式解决各种文本处理问题。

    正则表达式在PHP中的应用.pdf

    PHP支持POSIX扩展和PCRE(Perl Compatible Regular Expressions)两种正则表达式语法。 1. 正则表达式的基本概念 正则表达式是由特殊字符和普通字符组成的字符串,它们共同定义了一个模式,这个模式可以用来匹配一...

    PHP正则表达式基本语法和使用方法

    在PHP中支持PCRE(Perl Compatible Regular Expression)和POSIX(Portable Operation System interface)两套正则表达式处理函数,两套函数库功能相似,在执行效率上PCRE略占优势,因此自PHP 5.3.0版本以后POSIX正则...

    php正则表达式.doc

    PHP支持两种正则表达式模式:Perl兼容(PCRE)和Posix标准。 在PHP中,正则表达式的使用通常涉及以下函数: 1. `ereg`:这是最基本的正则表达式匹配函数,它检查字符串是否与给定的正则表达式匹配。 2. `ereg_...

Global site tag (gtag.js) - Google Analytics