前言
正则表达式几乎所有的主流的语言都支持它,比如python、Java、html。只是各有各的方法。例如java的match()方法,万变不离其宗。它依然是检索文字的不二之选,但你以为它的功能只有检索吗,那你就错了,它更多地用于可扩展上面。像邮件的验证,网络的爬虫,防乱注入等等。可以说是一个适应于各种编译环境的语言。因为它是一句话,不需要任何编译器。打个比方,就像变量,它需要编译器吗。
推荐
在进入正题之前我推荐一个正则表达式的在线测试工具,以方便随时测试正则表达式。站长工具:http://tool.chinaz.com/regex/
好了,下面进入正题
第一种方式,直接搜索绝对匹配的文本,就像你在任意一个文本编辑器里边按ctrl+f一样傻瓜式搜索,比如说你要在“今天是个好日子”里面搜索“今天”那你就直接ctrl+f+“今天”。这种方法是最简单最普遍的。然而遇到难的就不行了。
看一下下面这个例子:
在“adminu admina adminb administater”里面搜索包含”admin”的单词。如果你光输入“admin”是的得不到整个单词的。
1、“.”号
如何找到“adminu、admina、adminb”呢,可以发现,这三个有一个规律,就是admin后面只跟一个字符,那么“.”号可以解决。它的含义是包含前面所有的字符并且再外带一个字符。相当于匹配任意的以为字符。例如:c.t可以匹配到“cat、cut、cmt”但是看好了,只是一位,也就是说,多于一位的匹配不到,c.t就匹配不到coot了。
2、“\”号
它是一个元字符,表示这个字符有特殊的含义,而不是字符本身的含义。就拿上个例子来说,如果一个文本里面有“.”号,想精确匹配到它像上一个一样直接输入符号的话会匹配到包含点号在内的所有字段:
那么我们就需要一个东西告诉电脑,我只需要“.”号,而不需要它的功能,这时候就需要写“\”了,“\”相当于指定后面跟的字符,它仅仅是字符,不代表任何语法的含义,像这样:
好了,今天就写到这里,其实写博客的过程,相当于自己巩固的过程,所以,不需要太多,我每次更新几个就够了,慢慢消化嘛!(PS:且听下回分解)