美文网首页python学习日志
正则表达式(二)

正则表达式(二)

作者: 叫我小包总 | 来源:发表于2019-04-28 23:47 被阅读0次

    例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的[]和()表示的含义是不一样的,通过前面的学习我们也知道,[]表示或关系,()表示且关系。

    相关文章

      网友评论

        本文标题:正则表达式(二)

        本文链接:https://www.haomeiwen.com/subject/gbosnqtx.html