zoukankan      html  css  js  c++  java
  • 模块 re

    正则表达式符号

    '.'     默认匹配除
    之外的任意一个字符,若指定flag DOTALL,则匹配任意字符,包括换行
    '^'     匹配字符开头,若指定flags MULTILINE,这种也可以匹配上(r"^a","
    abc
    eee",flags=re.MULTILINE)
    '$'     匹配字符结尾,或e.search("foo$","bfoo
    sdfsf",flags=re.MULTILINE).group()也可以
    '*'     匹配*号前的字符0次或多次,re.findall("ab*","cabb3abcbbac")  结果为['abb', 'ab', 'a']
    '+'     匹配前一个字符1次或多次,re.findall("ab+","ab+cd+abb+bba") 结果['ab', 'abb']
    '?'     匹配前一个字符1次或0次
    '{m}'   匹配前一个字符m次
    '{n,m}' 匹配前一个字符n到m次,re.findall("ab{1,3}","abb abc abbcbbb") 结果'abb', 'ab', 'abb']
    '|'     匹配|左或|右的字符,re.search("abc|ABC","ABCBabcCD").group() 结果'ABC'
    '(...)' 分组匹配,re.search("(abc){2}a(123|456)c", "abcabca456c").group() 结果 abcabca456c
     
     
    'A'    只从字符开头匹配,re.search("Aabc","alexabc") 是匹配不到的
    ''    匹配字符结尾,同$
    'd'    匹配数字0-9
    'D'    匹配非数字
    'w'    匹配[A-Za-z0-9]
    'W'    匹配非[A-Za-z0-9]
    's'     匹配空白字符、	、
    、
     , re.search("s+","ab	c1
    3").group() 结果 '	'
     
    '(?P<name>...)' 分组匹配 re.search("(?P<province>[0-9]{4})(?P<city>[0-9]{2})(?P<birthday>[0-9]{4})","371481199306143242").groupdict("city") 结果{'province': '3714', 'city': '81', 'birthday': '1993'}

    a=re.match(pattern, string)

    a.groups()存储元组

    # re.match(pattern, string, flags=re.I)       #从头开始搜索
    print(re.match("w+","!inet addr:192.168.40.107  Bcast:192.168.40.255  Mask:255.255.255.0" ))
    
    # re.search(pattern, string)        #匹配包含
    print(re.search("(?P<province>[0-9]{4})(?P<city>[0-9]{2})(?P<birth>[0-9]{4})", "22020419860509", flags=re.I).groupdict())
    
    # re.findall(pattern,string)        #匹配所有符合pattern的项目,然后结果以列表返回
    print(re.findall("D+", "DD2d4wefwe4234dar234d15A5AD5AFS54DW", flags=re.I))
    
    # re.split(pattern, string)         #以pattern为分隔符分割string
    print(re.split("d+", "DD2d4wefwe4234dar234d15A5AD5AFS54DW", flags=re.I))
    print(re.split("\\", r"C:acd"))      # 4个匹配后面的一个
    
    # re.sub(pattern, split, string)          #用split代替pattern来分割string
    print(re.sub("d+", "/", "DD2d4wefwe4234dar234d15A5AD5AFS54DW", count=3, flags=re.I))
    
    # re.finditer(pattern, string)      #迭代器
    print(re.finditer("D+", "DD2d4wefwe4234dar234d15A5AD5AFS54DW", flags=re.I))
    
    
    #flags介绍:
    re.I        #忽略大小写
    re.M        #多行模式
    re.S        #改变.的行为
  • 相关阅读:
    转:裸接口防护,避免恶意盗刷和爬取
    oracle = : := 和变量绑定 oracle通配符和运算符
    169.254地址无网关信息 ----- 解决方案 启动DHCP服务
    NAS DAS SAN 磁带机 tco
    linux 权限详解
    转载:哈希加密算法 MD5,SHA-1,SHA-2,SHA-256,SHA-512,SHA-3,RIPEMD-160
    MD5,SHA1 都是哈希 摘要算法 MD5+SALT BCRYPT
    iOS开发JSON字符串和字典互转
    iOS开发线程之NSThread
    iOS开发NSMutableArray数组越界处理
  • 原文地址:https://www.cnblogs.com/hinimix/p/8522078.html
Copyright © 2011-2022 走看看