1 / 42
文档名称:

正则表达式使用详解.doc

格式:doc   页数:42页
下载后只包含 1 个 DOC 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

正则表达式使用详解.doc

上传人:164922429 2015/9/11 文件大小:0 KB

下载得到文件列表

正则表达式使用详解.doc

相关文档

文档介绍

文档介绍:正则表达式使用详解(一)
如果我们问那些UNIX系统的爱好者他们最喜欢什么,答案除了稳定的系统和可以远程启动之外,十有八九的人会提到正则表达式;如果我们再问他们最头痛的是什么,可能除了复杂的进程控制和安装过程之外,还会是正则表达式。那么正则表达式到底是什么?如何才能真正的掌握正则表达式并正确的加以灵活运用?本文将就此展开介绍,希望能够对那些渴望了解和掌握正则表达式的读者有所助益。
入门简介
简单的说,正则表达式是一种可以用于模式匹配和替换的强有力的工具。我们可以在几乎所有的基于UNIX系统的工具中找到正则表达式的身影,例如,Vi编辑器,Perl或PHP脚本语言,以及awk或sed shell程序等。此外,象JavaScript这种客户端的脚本语言也提供了对正则表达式的支持。由此可见,正则表达式已经超出了某种语言或某个系统的局限,成为人们广为接受的概念和功能。
正则表达式可以让用户通过使用一系列的特殊字符构建匹配模式,然后把匹配模式与数据文件、程序输入以及WEB页面的表单输入等目标对象进行比较,根据比较对象中是否包含匹配模式,执行相应的程序。
举例来说,正则表达式的一个最为普遍的应用就是用于验证用户在线输入的邮件地址的格式是否正确。如果通过正则表达式验证用户邮件地址的格式正确,用户所填写的表单信息将会被正常处理;反之,如果用户输入的邮件地址与正则表达的模式不匹配,将会弹出提示信息,要求用户重新输入正确的邮件地址。由此可见正则表达式在
WEB应用的逻辑判断中具有举足轻重的作用。
基本语法
在对正则表达式的功能和作用有了初步的了解之后,我们就来具体看一下正则表达式的语法格式。
正则表达式的形式一般如下:
/love/
其中位于“/”定界符之间的部分就是将要在目标对象中进行匹配的模式。用户只要把希望查找匹配对象的模式内容放入“/”定界符之间即可。为了能够使用户更加灵活的定制模式内容,正则表达式提供了专门的“元字符”。所谓元字符就是指那些在正则表达式中具有特殊意义的专用字符,可以用来规定其前导字符(即位于元字符前面的字符)在目标对象中的出现模式。
较为常用的元字符包括: “+”, “*”,以及“?”。其中,“+”元字符规定其前导字符必须在目标对象? 续出现一次或多次,“*”元字符规定其前导字符必须在目标对象中出现零次或连续多次,而“?”元字符规定其前导对象必须在目标对象中连续出现零次或一次。
下面,就让我们来看一下正则表达式元字符的具体应用。
/fo+/
因为上述正则表达式中包含“+”元字符,表示可以与目标对象中的“fool”, “fo”, 或者“football”等在后面连续出现一个或多个字母o的字符串相匹配。
/eg*/
因为上述正则表达式中包含“*”元字符,表示可以与目标对象中的“easy”, “ego”, 或者“egg”等在字母e后面连续出现零个或多个字母g的字符串相匹配。
/Wil?/
因为上述正则表达式中包含“?”元字符,表示可以与目标对象中的“Win”, 或者“Wilson”,等在字母i后面连续出现零个或一个字母l的字符串相匹配。
除了元字符之外,用户还可以精确指定模式在匹配对象中出现的频率。例如,
/jim{2,6}/
上述正则表达式规定字符m可以在匹配对象中连续出现2-6次,因此,上述正则表达式可以同jimmy或jimmmmmy等字符串相匹配。
在对如何使用正则表达式有了初步了解之后,我们来看一下其它几个重要的元字符的使用方式。
\s:用于匹配单个空格符,包括tab键和换行符;
\S:用于匹配除单个空格符之外的所有字符;
\d:用于匹配从0到9的数字;
\w:用于匹配字母,数字或下划线字符;
\W:用于匹配所有与\w不匹配的字符;
. :用于匹配除换行符之外的所有字符。
(说明:我们可以把\s和\S以及\w和\W看作互为逆运算)
下面,我们就通过实例看一下如何在正则表达式中使用上述元字符。
/\s+/
上述正则表达式可以用于匹配目标对象中的一个或多个空格字符。
/\d000/
如果我们手中有一份复杂的财务报表,那么我们可以通过上述正则表达式轻而易举的查找到所有总额达千元的款项。
除了我们以上所介绍的元字符之外,正则表达式中还具有另外一种较为独特的专用字符,即定位符。定位符用于规定匹配模式在目标对象中的出现位置。
较为常用的定位符包括: “^”, “$”, “\b”以及“\B”。其中,“^”定位符规定匹配模式必须出现在目标字符串的开头,“$”定位符规定匹配模式必须出现在目标对象的结尾,\b定位符规定匹配模式必须出现在目标字符串的开头或结尾的两个边界之一,而“\B”定位符则规定匹配对象必须位于目标字符串的开头和结尾两个边界之内,即匹配对象既不能作

最近更新

浙教版六年级下册数学期末测试卷【能力提升】.. 6页

浙教版六年级下册数学期末测试卷含答案【夺分.. 7页

苏教版一年级下册科学期末测试卷【名师推荐】.. 9页

苏教版一年级下册科学期末测试卷含完整答案【.. 9页

苏教版一年级下册科学期末测试卷精品(黄金题.. 9页

苏教版二年级下册科学期末测试卷及完整答案(.. 6页

仓库管理员实习生劳动合同简易版 9页

苏教版二年级下册科学期末测试卷附完整答案【.. 6页

苏教版五年级上册科学期末测试卷及1套完整答案.. 8页

苏教版五年级上册科学期末测试卷含完整答案(.. 8页

苏教版五年级上册科学期末测试卷精品(有一套.. 9页

苏教版五年级上册科学期末测试卷(必刷) 7页

苏教版六年级上册科学期末测试卷及完整答案(.. 8页

苏教版六年级上册科学期末测试卷附完整答案(.. 7页

苏教版六年级下册数学期末测试卷加答案 6页

苏教版六年级下册数学期末测试卷含完整答案(.. 7页

苏教版六年级下册数学期末测试卷(原创题) 6页

苏教版六年级下册数学第二单元 圆柱与圆锥 测.. 6页

苏教版六年级下册数学第二单元 圆柱与圆锥 测.. 8页

苏教版六年级下册数学第六单元 正比例和反比例.. 7页

苏教版六年级下册数学第六单元 正比例和反比例.. 7页

苏教版六年级下册数学第六单元 正比例和反比例.. 7页

苏教版四年级下册科学期末测试卷及完整答案【.. 9页

苏教版四年级下册科学期末测试卷带答案(突破.. 10页

苏教版四年级下册科学期末测试卷附答案【夺分.. 9页

苏教版小学一年级下册科学期末测试卷及参考答.. 9页

苏教版小学一年级下册科学期末测试卷附参考答.. 9页

苏教版小学二年级下册科学期末测试卷【名校卷.. 8页

苏教版小学二年级下册科学期末测试卷精品【预.. 7页

苏教版小学四年级下册科学期末测试卷及参考答.. 8页