正则表达式的学习

正则基础

\b    是正则表达式的一个特殊代码,有人称它元字符。代表的是需要匹配的某个单词的开头或者结尾。有些单词有空格或者分隔符,但是\b并不管这些,它只匹配一个位置,也就是说,空格,分隔符它也比较。

.    是另一个元字符,表示匹配除了换行符以外的任意字符。

*    也是一个元字符,不过它代表的不是字符,也不是位置,而是数量。它制定*字符前边的内容可以连续重复使用任意次以使整个表达式得以匹配。

.*    连在一起,就表示任意数量除了换行以外的任意字符。

例子:\bhi\b.*\bLucy\b表示以hi开头,中间任意数量除换行以外的任意字符,并且以Lucy结尾。

\d    是一个新的元字符,匹配任意一个数字(可以是0,可以是1...)

-    不是元字符,其实它就只匹配它本身,可以称它链接符,也可以称它减号,由自己啦!

例子:0\d\d-\d\d\d\d\d\d\d表示0开头,后跟2个任意数字,接着是链接-,最后是7个任意数字。当然,避免重复,可以简化写出0\d{2}-\d{7}

\s    表示匹配任意空白符,包括空格,制表符(tab),换行符,中文全角空格等。

\w    匹配字母,数字,下划线,或者汉字等。

^    匹配字符串开始。

$    匹配字符串结束。

例子:

\ba\w*\b匹配以字母a开头的单词——先是某个单词开始处(\b),然后是字母a,然后是任意数量的字母或数字(\w*),最后是单词结束处(\b)。

\d+匹配1个或更多连续的数字。这里的+是和*类似的元字符,不同的是*匹配重复任意次(可能是0次),而+则匹配重复1次或更多次。

\b\w{6}\b匹配刚好6个字符的单词。

{n}    重复N次

{n, }    重复n次到更多次

{n,m}    重复n到m次

{5,12}    表示重复的次数不能少于5次,不能多于12次。

例子:^\d{5,12}$匹配一个5-12位的数字。

\    表示转义符。比如你要匹配字符串中的.或者*等等,匹配不到,可以用\.或者\*当然,你要匹配\的话,就用\\

+    和*相似,但是+表示重复一次或多次。

?    重复0次或1次。

[ ]    指定一个范围。[0-9]表示一位数字,[a-zA-Z]

例子:\(?0\d{2}[) -]?\d{8}这个表达式可以匹配几种格式的电话号码,像(010)88886666,或022-22334455,或02912345678等。我们对它进行一些分析吧:首先是一个转义字符\(,它能出现0次或1次(?),然后是一个0,后面跟着2个数字(\d{2}),然后是)或-或空格中的一个,它出现1次或不出现(?),最后是8个数字(\d{8})。

不幸的是,上面那个例子也能匹配010)12345678或(022-87654321这样的“不正确”的格式。要解决这个问题,我们需要用到分枝条件。正则表达式里的分枝条件指的是有几种规则,如果满足其中任意一种规则都应该当成匹配,具体方法是用|把不同的规则分隔开。

|    分割不同的规则,但是使用时候要严格注意匹配顺序,因为如果符合第一个条件,就不会审核第二个条件了。

例子:0\d{2}-\d{8}|0\d{3}-\d{7}这个表达式能匹配两种以连字号分隔的电话号码:一种是三位区号,8位本地号(如010-12345678),一种是4位区号,7位本地号(0376-2233445)。

\(?0\d{2}\)?[-]?\d{8}|0\d{2}[- ]?\d{8}这个表达式匹配3位区号的电话号码,其中区号可以用小括号括起来,也可以不用,区号与本地号间可以用连字号或空格间隔,也可以没有间隔。

\d{5}-\d{4}|\d{5}如果你把它改成\d{5}|\d{5}-\d{4}的话,那么就只会匹配5位的邮编(以及9位邮编的前5位)。原因是匹配分枝条件时,将会从左到右地测试每个条件,如果满足了某个分枝的话,就不会去再管其它的条件了。

( )    重复多个字符,用()来指定子表达式,也可以叫做分组,可以指定( )中的元素重复多次。

例子:((2[0-4]\d|25[0-5]|[01]?\d\d?)\.){3}(2[0-4]\d|25[0-5]|[01]?\d\d?)判断正确的IP地址

\W    匹配任意不是字母,数字,下划线,汉字的字符

\S    匹配任意不是空白符的字符

\D    匹配任意非数字的字符

\B    匹配不是单词开头或结束的位置

[^x]    匹配除了x以外的任意字符

[^aeiou]    匹配除了aeiou这几个字母以外的任意字符

例子:\S+匹配不包含空白符的字符串。

]+>    匹配尖括号开始包含a打头字母的字符串。

正则匹配进阶

后向引用

使用小括号指定一个子表达式后,匹配这个子表达式的文本(也就是此分组捕获的内容)可以在表达式或其它程序中作进一步的处理。默认情况下,每个分组会自动拥有一个组号,规则是:从左向右,以分组的左括号为标志,第一个出现的分组的组号为1,第二个为2,以此类推。

后向引用用于重复搜索前面某个分组匹配的文本。例如,\1代表分组1匹配的文本。

例子:\b(\w+)\b\s+\1\b可以用来匹配重复的单词,像go go,或者kitty kitty。这个表达式首先是一个单词,也就是单词开始处和结束处之间的多于一个的字母或数字(\b(\w+)\b),这个单词会被捕获到编号为1的分组中,然后是1个或几个空白符(\s+),最后是分组1中捕获的内容(也就是前面匹配的那个单词)(\1)。

捕获

(exp)    匹配exp,并捕获文本到自动命名的组里

(?exp)    匹配exp,并捕获文本到名称为name的组里,也可以写成(?'name'exp)

(?:exp)    匹配exp,不捕获匹配的文本,也不给此分组分配组号

引用

\k(Word)反向引用这个分组捕获的内容

零宽断言

(?=exp)    匹配exp前面的位置

(?<=exp)    匹配exp后面的位置

(?!exp)    匹配后面跟的不是exp的位置

注释

(?#comment)  这种类型的分组不对正则表达式的处理产生任何影响,用于提供注释让人阅读

例子:\b(\w+)\b\s+\1\b通过上面介绍,可以改写成\b(?\w+)\b\s+\k\b

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容

  • 正则表达式到底是什么东西?字符是计算机软件处理文字时最基本的单位,可能是字母,数字,标点符号,空格,换行符,汉字等...
    狮子挽歌阅读 2,141评论 0 9
  • 注:本篇文章只为方便查看,特此保留,如有冒犯,敬请谅解!!! 本文目标 30分钟内让你明白正则表达式是什么,并对它...
    阿杰Alex阅读 1,480评论 0 10
  • 在工作中我们经常遇到这样的需求: 1.给你一个字符串,把字符串里面的链接、数字、电话等显示不同的颜色; 2.给你一...
    编程的蚂蚁阅读 4,946评论 6 7
  • 转载自正则表达式30分钟入门教程 入门 学习正则表达式的最好方法是从例子开始,理解例子之后再自己对例子进行修改,实...
    夏天的风_song阅读 1,700评论 0 0
  • 一朝离别两颗心,三生思念四海情, 五里长廊共佳人,六月雨淋淋。 七夕牛郎鹊桥解相思,八行相思引, 九方飞鸽寄何处,...
    梦怡峒阅读 114评论 0 0