• 20171115_Python学习五周三次课


    今日任务:

    五周三次课(11月15日)
    11.4 re的matche方法和search方法
    11.5 re的split,findall,finditer方法
    11.6 re的match对象

    match方法

    match(string[, pos[, endpos]])

    string:匹配使用的文本,

    pos: 文本中正则表达式开始搜索的索引。及开始搜索string的下标

    endpos: 文本中正则表达式结束搜索的索引。

    如果不指定pos,默认是从开头开始匹配,如果匹配不到,直接返回None

    import re

    pattern = re.compile(r'w*(hello w.*)(hello l.*)')

    result = pattern.match(r'aahello world hello ling')

    print(result)

    result2 = pattern.match(r'hello world hello ling')

    print(result2.groups())

    结果:

    None

    ('hello world ', 'hello ling')

    解释:如果不指定pos的话,默认是从字符串开始位置匹配,匹配不到就返回None,以上所有的pattern都是一个match对象。

    search方法

    search(string[, pos[, endpos]])

    这个方法用于查找字符串中可以匹配成功的子串。从string的pos下标处起尝试匹配pattern,如果pattern结束时仍可匹配,则返回一个Match对象;若无法匹配,则将pos加1后重新尝试匹配;直到pos=endpos时仍无法匹配则返回None。下面看个列子:

    import re

    pattern = re.compile(r'(hello w.*)(hello l.*)')

    result1 = pattern.search(r'aahello world hello ling')

    print(result1.groups())

    结果:

    ('hello world ', 'hello ling')

    解释:

    split方法

    split(string[, maxsplit])

    按照能够匹配的子串将string分割后返回列表。maxsplit用于指定最大分割次数,不指定将全部分割。

    import re

    p = re.compile(r'd+')

    print(p.split('one1two2three3four4'))

    结果:

    ['one', 'two', 'three', 'four', '']

    解释:直接把p的正则当成是分隔符,然后把最后的字符串用p进行分割,然后返回回去

    findall方法

    findall(string[, pos[, endpos]]) 

    搜索string,以列表形式返回全部能匹配的子串.

    import re

    p = re.compile(r'd+')

    print(findall('one1two2three3four4'))

    结果:

    ['1', '2', '3', '4']

    结果:findall是把匹配到的字符串最后一列表的形式返回回去

    finditer方法

    finditer(string[, pos[, endpos]])

    搜索string,返回一个顺序访问每一个匹配结果(Match对象)的迭代器。

    import re

    p = re.compile(r'd+')

    print(type(p.finditer('one1two2three3four4')))

    for m in p.finditer('one1two2three3four4'):

        print(type(m))

    print(m.group())

    结果:<type 'callable-iterator'>

    <type '_sre.SRE_Match'>

    1

    <type '_sre.SRE_Match'>

    2

    <type '_sre.SRE_Match'>

    3

    <type '_sre.SRE_Match'>

    4

    解释:

    p.finditer('one1two2three3four4')是一个迭代器,而返回的每个m都是match对象

    sub方法

    sub(repl, string[, count]) 

    使用repl替换string中每一个匹配的子串后返回替换后的字符串。

    当repl是一个字符串时,可以使用id或g<id>、g<name>引用分组,但不能使用编号0。

    当repl是一个方法时,这个方法应当只接受一个参数(Match对象),并返回一个字符串用于替换(返回的字符串中不能再引用分组)。

    count用于指定最多替换次数,不指定时全部替换。

    import re

    p = re.compile(r'(w+) (w+)')

    s = 'i say, hello world!'

    print(p.sub(r'2 1', s))

    def func(m):

        return m.group(1).title() + ' ' + m.group(2).title()

    print(p.sub(func, s))

    结果:

    say i, world hello!

    I Say, Hello World!

    解释:

    (id)就是匹配的括号的内容,id从默认从1开始计数

    m.group(1)是一个字符串,调用字符串的title()方法,所有单词的搜字母大写。

    match匹配对象

    Match对象是一次匹配的结果,包含了很多关于此次匹配的信息,可以使用Match提供的可读属性或方法来获取这些信息。上面的过程中多次使用了match对象,调用了他的group()和groups()等方法。

    例子

    import re

    prog = re.compile(r'(?P<tagname>abc)(.*)(?P=tagname)')

    result1 = prog.match('abclfjlad234sjldabc')

    print(result1)

    print(result1.groups())

    print result1.group('tagname')

    print(result1.group(2))

    print(result1.groupdict())

    结果:

    <_sre.SRE_Match object at 0x0000000002176E88>

    ('abc', 'lfjlad234sjld')

    abc

    lfjlad234sjld

    {'tagname': 'abc'}

    解释:

    1,我们可以看到result1已经由字符串转换成了一个正则对象。

    2,resule.groups()可以查看出来所有匹配到的数据,每个()是一个元素,最终返回一个tuple

    3,group()既可以通过下标(从1开始)的方式访问,也可以通过分组名进行访问。

    4,groupdict只能显示有分组名的数据

    group([group1, …]): 
    获得一个或多个分组截获的字符串;指定多个参数时将以元组形式返回。group1可以使用编号也可以使用别名;编号0代表整个匹配的子串;不填写参数时,返回group(0);没有截获字符串的组返回None;截获了多次的组返回最后一次截获的子串。

    groups([default]): 
    以元组形式返回全部分组截获的字符串。相当于调用group(1,2,…last)。default表示没有截获字符串的组以这个值替代,默认为None。

    groupdict([default]): 
    返回以有别名的组的别名为键、以该组截获的子串为值的字典,没有别名的组不包含在内。default含义同上。

  • 相关阅读:
    无聊的时候,冷死了(三)
    素数测试算法(基于Miller-Rabin的MC算法) // Fermat素数测试法
    英语笔记
    大数乘法
    jsp的session完成登陆功能
    java中如何制定自定义异常
    jsp获取请求头信息
    JSP的taglib示例
    JSP的自定义标签
    java中路径中参数值是中文,打印到页面是乱码的解决方案
  • 原文地址:https://www.cnblogs.com/zhuntidaoren/p/7841250.html
Copyright © 2020-2023  润新知