正则表达式(二)

例1

import re

a= 'pytho0python1pythonn2'

r= re.findall('python*',a)

r1= re.findall('python{1,2}?',a)

r2= re.findall('python?',a)

r3= re.findall('python{1,2}',a)

print(r)

print(r1)

print(r2)

print(r3)


给定一个字符串,然后按要求从里面检索出Python。

其中,「*」表示匹配*前面的字符零次或无限次;

      「+」表示匹配+前面的字符1次或无限多次;

      「?」表示匹配?前面的字符0次或1次,这里需要注意的是,在代码中打印r2结果出现了2个Python,这是由于?具有去重的功能。


例2:边界匹配

import re

# qq = '100001'

qq= '100000001'

#验证qq号是否符合4-8位

r= re.findall('^\d{4,8}$',qq)

r1= re.findall('000',qq)

# 如果在开头加入^,不能匹配,字符串开头是1;在末尾加上$,不能匹配,最后的字母必须是000

print(r)

print(r1)


应用场景,验证QQ号是否符合4-8位。

如果符合就打印出结果,否则就打印出[]。但是,通过这行代码,会出现一个问题,当QQ号有九位时,也会打印出前八位的结果,为了防止出现这种错误的结果,我们将上述代码修正为

r= re.findall('^\d{4,8}$',qq)

正则表达式中,「^」和「$」就是边界匹配,前者表示从字符串开头开始匹配,后者则从字符串末尾开始匹配,这样当给出的QQ号超出需要验证的范围时,就会打印出[]。

继续看上面代码,打印r1时会出现

['000','000']

这是因为Python的分组机制,字符串中间有7个0,Python会自动分成2组,如果我们在正则表达式前面加「^」,则会打印出[],这是因为「^」从开头开始匹配,但是开头第一个字符是1,当检索出是1时,就自动停止了匹配,从而打印出[]。同样的,如果在正则表达式末尾加「$」,也会出现[]。

例3:组

import re

a= 'pythonpythonpythonpythonpython'

r= re.findall('(python){3}',a)#Python在正则表达式重复的表示出来

print(r)


检索出字符串中所有的Python,当考虑检索Python的次数上升到很大的数量级时,我们需要这样定义正则表达式。

一个括号表示1组,后面{}的数量词表示重复的次数。

最后,Python的[]和()表示的含义是不一样的,通过前面的学习我们也知道,[]表示或关系,()表示且关系。

你可能感兴趣的:(正则表达式(二))