`
hereson
  • 浏览: 1449953 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
社区版块
存档分类
最新评论

1小时教你学会正则表达式

阅读更多
想必很多人都对正则表达式都头疼.今天,我以我的认识,加上网上一些文章,希望用常人都可以理解的表达方式.来和大家分享学习经验.  开篇,还是得说说 ^ 和 $ 他们是分别用来匹配字符串的开始和结束,以下分别举例说明

  "^The": 开头一定要有"The"字符串;
  "of despair$": 结尾一定要有"of despair" 的字符串;

  那么,
  "^abc$": 就是要求以abc开头和以abc结尾的字符串,实际上是只有abc匹配
  "notice": 匹配包含notice的字符串

  你可以看见如果你没有用我们提到的两个字符(最后一个例子),就是说 模式(正则表达式) 可以出现在被检验字符串的任何地方,你没有把他锁定到两边
  接着,说说 '*', '+',和 '?',
  他们用来表示一个字符可以出现的次数或者顺序. 他们分别表示:
  "zero or more"相当于{0,},
  "one or more"相当于{1,},
  "zero or one."相当于{0,1}, 这里是一些例子:

  "ab*": 和ab{0,}同义,匹配以a开头,后面可以接0个或者N个b组成的字符串("a", "ab", "abbb", 等);
  "ab+": 和ab{1,}同义,同上条一样,但最少要有一个b存在 ("ab", "abbb", 等.);
  "ab?":和ab{0,1}同义,可以没有或者只有一个b;
  "a?b+$": 匹配以一个或者0个a再加上一个以上的b结尾的字符串.
  要点, '*', '+',和 '?'只管它前面那个字符.


  你也可以在大括号里面限制字符出现的个数,比如

  "ab{2}": 要求a后面一定要跟两个b(一个也不能少)("abb");
  "ab{2,}": 要求a后面一定要有两个或者两个以上b(如"abb", "abbbb", 等.);
  "ab{3,5}": 要求a后面可以有2-5个b("abbb", "abbbb", or "abbbbb").

  现在我们把一定几个字符放到小括号里,比如:
  "a(bc)*": 匹配 a 后面跟0个或者一个"bc";
  "a(bc){1,5}": 一个到5个 "bc."

  还有一个字符 '│', 相当于OR 操作:

  "hi│hello": 匹配含有"hi" 或者 "hello" 的 字符串;
  "(b│cd)ef": 匹配含有 "bef" 或者 "cdef"的字符串;
  "(a│b)*c": 匹配含有这样多个(包括0个)a或b,后面跟一个c 的字符串;

  一个点('.')可以代表所有的单一字符,不包括"\n"
  如果,要匹配包括"\n"在内的所有单个字符,怎么办?
  对了,用'[\n.]'这种模式.

  "a.[0-9]": 一个a加一个字符再加一个0到9的数字
  "^.{3}$": 三个任意字符结尾 .

  中括号括住的内容只匹配一个单一的字符

  "[ab]": 匹配单个的 a 或者 b ( 和 "a│b" 一样);
  "[a-d]": 匹配'a' 到'd'的单个字符 (和"a│b│c│d" 还有 "[abcd]"效果一样); 一般我们都用[a-zA-Z]来指定字符为一个大小写英文
  "^[a-zA-Z]": 匹配以大小写字母开头的字符串
  "[0-9]%": 匹配含有 形如 x% 的字符串
  ",[a-zA-Z0-9]$": 匹配以逗号再加一个数字或字母结尾的字符串

  你也可以把你不想要得字符列在中括号里,你只需要在总括号里面使用'^' 作为开头 "%[^a-zA-Z]%" 匹配含有两个百分号里面有一个非字母的字符串.

  要点:^用在中括号开头的时候,就表示排除括号里的字符

  为了PHP能够解释,你必须在这些字符面前后加'',并且将一些字符转义.
  不要忘记在中括号里面的字符是这条规路的例外—在中括号里面, 所有的特殊字符,包括(''), 都将失去他们的特殊性质 "[*\+?{}.]"匹配含有这些字符的字符串.
  还有,正如regx的手册告诉我们: "如果列表里含有 ']', 最好把它作为列表里的第一个字符(可能跟在'^'后面). 如果含有'-', 最好把它放在最前面或者最后面, or 或者一个范围的第二个结束点[a-d-0-9]中间的‘-’将有效.
  看了上面的例子,你对{n,m}应该理解了吧.要注意的是,n和m都不能为负整数,而且n总是小于m. 这样,才能 最少匹配n次且最多匹配m次. 如"p{1,5}"将匹配 "pvpppppp"中的前五个p
  下面说说以\开头的
  \b 书上说他是用来匹配一个单词边界,就是...比如've\b',可以匹配love里的ve而不匹配very里有ve
  \B 正好和上面的\b相反.例子我就不举了
  好,我们来做个应用:
  如何构建一个模式来匹配 货币数量 的输入
  构建一个匹配模式去检查输入的信息是否为一个表示money的数字。我们认为一个表示money的数量有四种方式: "10000.00" 和 "10,000.00",或者没有小数部分, "10000" and "10,000". 现在让我们开始构建这个匹配模式:
  ^[1-9][0-9]*$
  这是所变量必须以非0的数字开头.但这也意味着 单一的 "0" 也不能通过测试. 以下是解决的方法:
  ^(0│[1-9][0-9]*)$
  "只有0和不以0开头的数字与之匹配",我们也可以允许一个负号在数字之前:
  ^(0│-?[1-9][0-9]*)$
  这就是: "0 或者 一个以0开头 且可能 有一个负号在前面的数字." 好了,现在让我们别那么严谨,允许以0开头.现在让我们放弃负号 , 因为我们在表示钱币的时候并不需要用到. 我们现在指定 模式 用来匹配小数部分:
  ^[0-9]+(\.[0-9]+)?$

  这暗示匹配的字符串必须最少以一个阿拉伯数字开头. 但是注意,在上面模式中 "10." 是不匹配的, 只有 "10" 和 "10.2" 才可以. (你知道为什么吗)
  ^[0-9]+(\.[0-9]{2})?$
  我们上面指定小数点后面必须有两位小数.如果你认为这样太苛刻,你可以改成:
  ^[0-9]+(\.[0-9]{1,2})?$
  这将允许小数点后面有一到两个字符. 现在我们加上用来增加可读性的逗号(每隔三位), 我们可以这样表示:
  ^[0-9]{1,3}(,[0-9]{3})*(\.[0-9]{1,2})?$
  不要忘记 '+' 可以被 '*' 替代 如果你想允许空白字符串被输入话 (为什么?). 也不要忘记反斜杆 ’\’ 在php字符串中可能会出现错误 (很普遍的错误).

  现在,我们已经可以确认字符串了, 我们现在把所有逗号都去掉 str_replace(",", "", $money) 然后在把类型看成 double然后我们就可以通过他做数学计算了.

  再来一个:
  构造检查email的正则表达式
  在一个完整的email地址中有三个部分:
  1. 用户名 (在 '@' 左边的一切),
  2.'@',
  3. 服务器名(就是剩下那部分).
  用户名可以含有大小写字母阿拉伯数字,句号 ('.'), 减号('-'), and 下划线 ('_'). 服务器名字也是符合这个规则,当然下划线除外.

  现在, 用户名的开始和结束都不能是句点. 服务器也是这样. 还有你不能有两个连续的句点他们之间至少存在一个字符,好现在我们来看一下怎么为用户名写一个匹配模式:

  ^[_a-zA-Z0-9-]+$
  现在还不能允许句号的存在. 我们把它加上:
  ^[_a-zA-Z0-9-]+(\.[_a-zA-Z0-9-]+)*$
  上面的意思就是说: "以至少一个规范字符(除了.)开头,后面跟着0个或者多个以点开始的字符串."

  简单化一点, 我们可以用 eregi()取代 ereg().eregi()对大小写不敏感, 我们就不需要指定两个范围 "a-z" 和 "A-Z" – 只需要指定一个就可以了:
  ^[_a-z0-9-]+(\.[_a-z0-9-]+)*$
  后面的服务器名字也是一样,但要去掉下划线:
  ^[a-z0-9-]+(\.[a-z0-9-]+)*$
  好. 现在只需要用”@”把两部分连接:
  ^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*$

  这就是完整的email认证匹配模式了,只需要调用
  eregi(‘^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*$ ’,$eamil)
  就可以得到是否为email了
  正则表达式的其他用法
  提取字符串
  ereg() and eregi() 有一个特性是允许用户通过正则表达式去提取字符串的一部分,比如说,我们想从 path/URL 提取文件名 – 下面的代码就是你需要:
  ereg("([^\\/]*)$", $pathOrUrl, $regs);
  echo $regs[1];
  高级的代换
  ereg_replace() 和 eregi_replace()也是非常有用的: 假如我们想把所有的间隔负号都替换成逗号:
  ereg_replace("[ \n\r\t]+", ",", trim($str));
  最后,我把另一串检查EMAIL的正则表达式让看文章的你来分析一下.
  "^[-!#$%&\'*+\\./0-9=?A-Z^_`a-z{|}~]+'.'@'.'[-!#$%&\'*+\\/0-9=?A-Z^_`a-z{|}~]+\.'.'[-!#$%&\'*+\\./0-9=?A-Z^_`a-z{|}~]+$"
  如果能方便的读懂,那这篇文章的目的就达到了
附加:

正则表达式用于字符串处理,表单验证等场合,实用高效,但用到时总是不太把握,以致往往要上网查一番。我将一些常用的表达式收藏在这里,作备忘之用。本贴随时会更新。

匹配中文字符的正则表达式: [\u4e00-\u9fa5]

匹配双字节字符(包括汉字在内):[^\x00-\xff]

应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)

String.prototype.len=function(){return this.replace([^\x00-\xff]/g,"aa").length;}

匹配空行的正则表达式:\n[\s| ]*\r

匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*) \/>/

匹配首尾空格的正则表达式:(^\s*)|(\s*$)

 

String.prototype.trim = function()
{
     return this.replace(/(^\s*)|(\s*$)/g, "");
}

利用正则表达式分解和转换IP地址:

下面是利用正则表达式匹配IP地址,并将IP地址转换成对应数值的Javascript程序:

function IP2V(ip)
{
re=/(\d+)\.(\d+)\.(\d+)\.(\d+)/g   //匹配IP地址的正则表达式
if(re.test(ip))
{
return RegExp.$1*Math.pow(255,3))+RegExp.$2*Math.pow(255,2))+RegExp.$3*255+RegExp.$4*1
}
else
{
throw new Error("Not a valid IP address!")
}
}

不过上面的程序如果不用正则表达式,而直接用split函数来分解可能更简单,程序如下:

var ip="10.100.20.168"
ip=ip.split(".")
alert("IP值是:"+(ip[0]*255*255*255+ip[1]*255*255+ip[2]*255+ip[3]*1))

匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*

匹配网址URL的正则表达式:http://([\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?

利用正则表达式去除字串中重复的字符的算法程序:[注:此程序不正确,原因见红色字体]

var s="abacabefgeeii"
var s1=s.replace(/(.).*\1/g,"$1")
var re=new RegExp("["+s1+"]","g")
var s2=s.replace(re,"")
alert(s1+s2)   //结果为:abcefgi

===============================
如果var s = "abacabefggeeii"
结果就不对了,结果为:abeicfgg
正则表达式的能力有限


我原来在CSDN上发贴寻求一个表达式来实现去除重复字符的方法,最终没有找到,这是我能想到的最简单的实现方法。思路是使用后向引用取出包括重复的字符,再以重复的字符建立第二个表达式,取到不重复的字符,两者串连。这个方法对于字符顺序有要求的字符串可能不适用。

得用正则表达式从URL地址中提取文件名的javascript程序,如下结果为page1

s="http://www.9499.net/page1.htm"
s=s.replace(/(.*\/){0,}([^\.]+).*/ig,"$2")
alert(s)

利用正则表达式限制网页表单里的文本框输入内容:

用正则表达式限制只能输入中文:onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,''))"

用正则表达式限制只能输入全角字符: onkeyup="value=value.replace(/[^\uFF00-\uFFFF]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\uFF00-\uFFFF]/g,''))"

用正则表达式限制只能输入数字:onkeyup="value=value.replace(/[^\d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"

用正则表达式限制只能输入数字和英文:onkeyup="value=value.replace(/[\W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"


分享到:
评论

相关推荐

    正则表达式教程和配套测试工具regextester

    非常棒的正则表达式速成教程,号称30分钟叫你学会正则表达式常用用法。我本人学了一下,感觉不赖,不过俺比较笨,30分钟的东西学了3个多小时,已经从什么都不会变成会编各种复杂的正则筛选条件了^^!这个教程是配合...

    javascript 30分钟学会正则表达式

    "javascript 30分钟学会正则表达式"的教程旨在帮助你快速理解和应用正则表达式,无论你是初学者还是希望巩固正则知识的开发者。 首先,我们要了解正则表达式的构成元素。基础的元素包括元字符(如.、*、+、?、^、$...

    半小时学会正则表达式教程

    通过使用正则表达式,你可以精确地定义你想要查找的字符串模式,从而在大量数据中快速定位你需要的信息。 在本文中,作者 Deerchao 提供了一个30分钟的正则表达式入门教程,旨在帮助读者理解正则表达式的概念并开始...

    30分钟学会正则表达式

    通过阅读《正则表达式参考.chm》、《正则表达式系统教程.CHM》、《正则表达式30分钟入门教程.mht》和《正则表达式.pdf》这些文档,你可以深入理解并熟练运用正则表达式。实践中不断尝试和调试,将使你的正则表达式...

    正则表达式系统教程.RAR

    通过这些例子,你可以看到正则表达式的强大功能,并学会如何根据具体需求编写自己的正则表达式。文件可能包含了多种匹配和不匹配的情况,帮助你理解正则表达式的灵活性和多样性。 《新建 文本文档.txt》可能是一份...

    三十分钟学会正则表达式

    本教程的目标是在30分钟内帮助你理解和初步掌握正则表达式的基本概念。 1. **元字符**:正则表达式中的元字符具有特殊含义,例如`\b`表示单词边界,`.`代表任何单个非换行符的字符,`*`表示前面的字符可以重复0次或...

    “正则表达式”教程.rar

    1. 理解并使用基本的正则表达式元字符和量词。 2. 掌握预定义字符类及其应用。 3. 学会使用正则表达式进行字符串匹配和提取。 4. 在易语言中实现正则表达式的功能。 5. 解决实际编程中遇到的文本处理问题。 请打开...

    Python基础入门知识之正则表达式学习 正则表达式30分钟入门教程 共21页.pdf

    本教程的目标是让读者快速理解正则表达式的概念,学会基本的语法结构,并能应用到实际的Python代码中,进行字符串匹配和处理。 二、如何使用本教程 建议读者跟随教程的步骤,逐步实践每个例子,加深理解和记忆。...

    教你在30分钟学会正则表达式

    通过上述知识点的学习,你将在接下来的30分钟内建立起对正则表达式的基本认识,并能够在实际开发中运用它们解决常见的文本处理问题。当然,随着时间的推移,不断加深对正则表达式的理解,你会变得更加熟练。

    正则表达式chm学习教程

    通过本教程,你将学会如何构建简单的正则表达式,理解复杂的模式,以及如何在各种编程语言中使用它们。 总之,正则表达式是数据处理的利器,虽然初学时可能会感到有些复杂,但一旦掌握了,就能大幅提升处理文本数据...

    轻松使用正则表达式之道

    在"半小时轻松学会使用正则表达式,从此不再愁"的学习资源中,你将掌握正则表达式的精髓,提升你的文本处理技能。 1. **基础概念**: - **元字符**:如`.`代表任意字符,`\d`代表数字,`\s`代表空白字符等。 - **...

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

    同时,正则表达式的调试也是学习过程中的重要环节,读者将学会如何使用各种工具(如Perl的 `perl -ne` 或在线的正则表达式测试器)来验证和调试自己的正则表达式。 本书的中文版为国内读者提供了更易理解的语言环境...

    学习正则表达式 Michael Fitzgerald

    10. **实际应用**:书中会提供大量实例,教你如何在JavaScript、Python、Java等语言中使用正则表达式解决实际问题。 11. **调试与测试**:学习使用正则表达式测试工具,如在线的RegExr或文本编辑器内置的正则匹配...

Global site tag (gtag.js) - Google Analytics