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

揭开正则表达式语法的神秘面纱

阅读更多

揭开正则表达式语法的神秘面纱<!----><o:p></o:p>

正则表达式(REs)通常被错误地认为是只有少数人理解的一种神秘语言。在表面上它们确实看起来杂乱无章,如果你不知道它的语法,那么它的代码在你眼里只是一堆文字垃圾而已。实际上,正则表达式是非常简单并且可以被理解。读完这篇文章后,你将会通晓正则表达式的通用语法。 <o:p></o:p>

支持多种平台<o:p></o:p>

<!----><!---->正则表达式最早是由数学家Stephen Kleene于1956年提出,他是在对自然语言的递增研究成果的基础上提出来的。具有完整语法的正则表达式使用在字符的格式匹配方面上,后来被应用到熔融信息技术领域。自从那时起,正则表达式经过几个时期的发展,现在的标准已经被ISO(国际标准组织)批准和被Open Group组织认定。<o:p></o:p>

正则表达式并非一门专用语言,但它可用于在一个文件或字符里查找和替代文本的一种标准。它具有两种标准:基本的正则表达式(BRE),扩展的正则表达式(ERE)。ERE包括BRE功能和另外其它的概念。<o:p></o:p>

许多程序中都使用了正则表达式,包括xsh,egrep,sed,vi以及在UNIX平台下的程序。它们可以被很多语言采纳,如HTML 和XML,这些采纳通常只是整个标准的一个子集。<o:p></o:p>

比你想象的还要普通<o:p></o:p>

随着正则表达式移植到交叉平台的程序语言的发展,这的功能也日益完整,使用也逐渐广泛。网络上的搜索引擎使用它,e-mail程序也使用它,即使你不是一个UNIX程序员,你也可以使用规则语言来简化你的程序而缩短你的开发时间。<o:p></o:p>

正则表达式101<o:p></o:p>

很多正则表达式的语法看起来很相似,这是因为你以前你没有研究过它们。通配符是RE的一个结构类型,即重复操作。让我们先看一看ERE标准的最通用的基本语法类型。为了能够提供具有特定用途的范例,我将使用几个不同的程序。<o:p></o:p>

字符匹配<o:p></o:p>

 <o:p></o:p>

正则表达式的关键之处在于确定你要搜索匹配的东西,如果没有这一概念,Res将毫无用处。

每一个表达式都包含需要查找的指令,如表A所示。<o:p></o:p>

Table A: Character-matching regular expressions<o:p></o:p>

操作<o:p></o:p>

解释<o:p></o:p>

例子<o:p></o:p>

结果<o:p></o:p>

.<o:p></o:p>

Match any one character<o:p></o:p>

grep .ord sample.txt<o:p></o:p>

Will match “ford”, “lord”, “2ord”, etc. in the file sample.txt.<o:p></o:p>

[ ]<o:p></o:p>

Match any one character listed between the brackets<o:p></o:p>

grep [cng]ord sample.txt<o:p></o:p>

Will match only “cord”, “nord”, and “gord”<o:p></o:p>

[^ ]<o:p></o:p>

Match any one character not listed between the brackets<o:p></o:p>

grep [^cn]ord sample.txt<o:p></o:p>

Will match “lord”, “2ord”, etc. but not “cord” or “nord”<o:p></o:p>

 <o:p></o:p>

 <o:p></o:p>

grep [a-zA-Z]ord sample.txt<o:p></o:p>

Will match “aord”, “bord”, “Aord”, “Bord”, etc.<o:p></o:p>

 <o:p></o:p>

 <o:p></o:p>

grep [^0-9]ord sample.txt<o:p></o:p>

Will match “Aord”, “aord”, etc. but not “2ord”, etc.<o:p></o:p>


重复操作符<o:p></o:p>

重复操作符,或数量词,都描述了查找一个特定字符的次数。它们常被用于字符匹配语法以查找多行的字符,可参见表B。<o:p></o:p>

Table B: Regular expression repetition operators<o:p></o:p>

操作<o:p></o:p>

解释<o:p></o:p>

例子<o:p></o:p>

结果<o:p></o:p>

?<o:p></o:p>

Match any character one time, if it exists<o:p></o:p>

egrep “?erd” sample.txt<o:p></o:p>

Will match “berd”, “herd”, etc. and “erd”<o:p></o:p>

*<o:p></o:p>

Match declared element multiple times, if it exists<o:p></o:p>

egrep “n.*rd” sample.txt<o:p></o:p>

Will match “nerd”, “nrd”, “neard”, etc.<o:p></o:p>

+<o:p></o:p>

Match declared element one or more times<o:p></o:p>

egrep “[n]+erd” sample.txt<o:p></o:p>

Will match “nerd”, “nnerd”, etc., but not “erd”<o:p></o:p>

{n}<o:p></o:p>

Match declared element exactly n times<o:p></o:p>

egrep “[a-z]{2}erd” sample.txt<o:p></o:p>

Will match “cherd”, “blerd”, etc. but not “nerd”, “erd”, “buzzerd”, etc.<o:p></o:p>

{n,}<o:p></o:p>

Match declared element at least n times<o:p></o:p>

egrep “.{2,}erd” sample.txt<o:p></o:p>

Will match “cherd” and “buzzerd”, but not “nerd”<o:p></o:p>

{n,N}<o:p></o:p>

Match declared element at least n times, but not more than N times<o:p></o:p>

egrep “n[e]{1,2}rd” sample.txt<o:p></o:p>

Will match “nerd” and “neerd”<o:p></o:p>

<o:p></o:p>

锚是指它所要匹配的格式,如图C所示。使用它能方便你查找通用字符的合并。例如,我用vi行编辑器命令:s来代表substitute,这一命令的基本语法是:<o:p></o:p>

s/pattern_to_match/pattern_to_substitute/
 <o:p></o:p>

Table C: Regular expression anchors<o:p></o:p>

操作<o:p></o:p>

解释<o:p></o:p>

例子<o:p></o:p>

结果<o:p></o:p>

^<o:p></o:p>

Match at the beginning of a line<o:p></o:p>

s/^/blah /<o:p></o:p>

Inserts “blah “ at the beginning of the line<o:p></o:p>

$<o:p></o:p>

Match at the end of a line<o:p></o:p>

s/$/ blah/<o:p></o:p>

Inserts “ blah” at the end of the line<o:p></o:p>

\<<o:p></o:p>

Match at the beginning of a word<o:p></o:p>

s/\</blah/<o:p></o:p>

Inserts “blah” at the beginning of the word<o:p></o:p>

 <o:p></o:p>

 <o:p></o:p>

egrep “\<blah” sample.txt<o:p></o:p>

Matches “blahfield”, etc.<o:p></o:p>

\><o:p></o:p>

Match at the end of a word<o:p></o:p>

s/\>/blah/<o:p></o:p>

Inserts “blah” at the end of the word<o:p></o:p>

 <o:p></o:p>

 <o:p></o:p>

egrep “\>blah” sample.txt<o:p></o:p>

Matches “soupblah”, etc.<o:p></o:p>

\b<o:p></o:p>

Match at the beginning or end of a word<o:p></o:p>

egrep “\bblah” sample.txt<o:p></o:p>

Matches “blahcake” and “countblah”<o:p></o:p>

\B<o:p></o:p>

Match in the middle of a word<o:p></o:p>

egrep “\Bblah” sample.txt<o:p></o:p>

Matches “sublahper”, etc.<o:p></o:p>

 <o:p></o:p>

间隔<o:p></o:p>

Res中的另一可便之处是间隔(或插入)符号。实际上,这一符号相当于一个OR语句并代表|符号。下面的语句返回文件sample.txt中的“nerd” 和 “merd”的句柄:<o:p></o:p>

egrep “(n|m)erd” sample.txt<o:p></o:p>

间隔功能非常强大,特别是当你寻找文件不同拼写的时候,但你可以在下面的例子得到相同的结果:<o:p></o:p>

egrep “[nm]erd” sample.txt<o:p></o:p>

当你使用间隔功能与Res的高级特性连接在一起时,它的真正用处更能体现出来。<o:p></o:p>

一些保留字符<o:p></o:p>

Res的最后一个最重要特性是保留字符(也称特定字符)。例如,如果你想要查找“ne*rd”和“ni*rd”的字符,格式匹配语句“n[ei]*rd”与“neeeeerd” 和 “nieieierd”相符合,但并不是你要查找的字符。因为‘*’(星号)是个保留字符,你必须用一个反斜线符号来替代它,即:“n[ei]\*rd”。其它的保留字符包括:<o:p></o:p>

  • ^ (carat) <o:p></o:p>
  • . (period) <o:p></o:p>
  • [ (left bracket} <o:p></o:p>
  • $ (dollar sign) <o:p></o:p>
  • ( (left parenthesis) <o:p></o:p>
  • ) (right parenthesis) <o:p></o:p>
  • | (pipe) <o:p></o:p>
  • * (asterisk) <o:p></o:p>
  • + (plus symbol) <o:p></o:p>
  • ? (question mark) <o:p></o:p>
  • { (left curly bracket, or left brace) <o:p></o:p>
  • \ backslash <o:p></o:p>

一旦你把以上这些字符包括在你的字符搜索中,毫无疑问Res变得非常的难读。比如说以下的PHP中的eregi搜索引擎代码就很难读了。<o:p></o:p>

eregi("^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*$",$sendto)<o:p></o:p>

你可以看到,程序的意图很难把握。但如果你抛开保留字符,你常常会错误地理解代码的意思。<o:p></o:p>

总结<o:p></o:p>

在本文中,我们揭开了正则表达式的神秘面纱,并列出了ERE标准的通用语法。如果你想阅览Open Group组织的规则的完整描述,你可以参见:Regular Expressions,欢迎你在其中的讨论区发表你的问题或观点。<o:p></o:p>

 <o:p></o:p>

分享到:
评论

相关推荐

    揭开正则表达式的神秘面纱.doc

    然而,这种灵活性也意味着正则表达式的语法可能会变得相当复杂,尤其是当涉及到更高级的功能如分组、引用、前瞻和回溯时。 ### 结论 掌握正则表达式的关键在于实践和理解其基本原理。一旦掌握了基本的符号和构造,...

    揭开正则表达式的神秘面纱

    正则表达式是一种强大的文本处理工具,用于模式匹配、搜索、替换等功能。它通过特定的语法,用一个字符串描述一个模式,然后判断另一个字符串是否符合这个模式。在计算机科学和编程领域,正则表达式广泛应用于数据...

    正则表达式参考文档揭开正则表达式的神秘面纱

    本文档将深入探讨正则表达式的概念、语法以及常见用法,旨在帮助读者揭开其神秘面纱。 一、正则表达式基础 1. 基本字符:正则表达式由一系列基本字符构成,如字母、数字、标点符号等。例如,字符"a"、"b"和"1"都是...

    揭开正则表达式的神秘面纱(doc)

    它通过一套特定的语法,即正则表达式规则,来定义字符串的特征。本文将深入解析正则表达式的基本概念和常用规则。 1. **普通字符** 普通字符包括字母、数字、汉字、下划线以及未被特殊定义的标点符号。它们在正则...

    正则表达式 正则表达式资料 正则表达式教程

    #### 2.2 regexlab.com的《揭开正则表达式的神秘面纱》 该资源提供了详细的讲解和实例,排版清晰整洁。无论是正准备入门的新手还是希望进一步提升技能的老手,都能从中获益良多。通过学习这一资源,读者可以更好地...

    正则表达式 电子书 教程 chm

    总之,正则表达式是一门深奥且强大的技术,虽然初学者可能觉得它复杂难懂,但只要通过系统的教程学习,如本教程提供的CHM电子书,便能逐步揭开其神秘面纱,轻松应对各种文本处理挑战。无论你是网站开发人员、数据...

    正则表达式必知必会

    正则表达式(Regular Expression,简称regex)是用于匹配字符串的一种模式,广泛...《正则表达式必知必会》这本书无疑是入门的最佳选择,它将带领读者逐步揭开正则表达式的神秘面纱,帮助你快速理解和运用这一技术。

    编译原理大学课件

    编译原理是计算机科学...编译原理虽然不易学,但通过系统学习,我们可以逐步揭开编译器的神秘面纱,为将来从事软件开发、系统优化等工作打下坚实的基础。希望所有学习者都能在这个过程中不断进步,掌握这项核心技术。

    python编程实例

    Python编程实例是一个面向初学者和进阶者的学习资源,它包含了一系列实际的源代码示例,旨在帮助Python爱好者深入理解语言...在探索"examples"文件夹的过程中,你将会逐步揭开Python编程的神秘面纱,领略其无穷的魅力。

    编译系统透视 图解编译原理

    《编译系统透视:图解编译原理》是深入理解计算机科学中不可或缺的一环,它为我们揭示了程序语言从源代码到...通过阅读《编译系统透视:图解编译原理》,读者可以逐步揭开编译器神秘的面纱,从而更好地驾驭编程世界。

    “龙书”编译原理中的编译器前端实例.

    在编程领域,编译器是将高级编程语言转换为机器可执行代码的关键工具。"龙书",全称《编译程序设计》...一旦你对这些基础知识有了扎实的理解,就可以开始探索这个编译器前端的源码,逐步揭开编译器神秘的面纱。

    《编译原理》

    在《编译原理》这本书中,读者会深入学习到以上各个阶段的细节,包括正则表达式、上下文无关文法、LL和LR解析技术、递归下降解析、语法制导翻译、静态和动态语义、数据流分析、控制流分析以及各种代码优化技术。...

    计算理论导引介绍自动机及可计算性理论

    通过系统学习本书,读者可以更好地理解计算机科学的基本理论,并在实际工作中运用这些理论指导实践,比如在设计新的编程语言时运用语法知识,或在进行字符串搜索和模式匹配时借助有穷自动机和正则表达式等工具。...

    python 源码剖析

    在Python编程语言的世界里,源码剖析是提升技能和深入理解其内部机制的关键步骤。...在codefans.net这样的资源网站上,你可能会找到许多关于Python源码的分析文章和教程,帮助你一步步揭开Python的神秘面纱。

Global site tag (gtag.js) - Google Analytics