day18 - 正则表达式

day18 - 正则表达式

一 . 匹配类符号

  1. 正则表达式

    • 正则表达式是一种可以让一些复杂的字符串问题变得简单的工具。
  2. 正则语法(通用)

    • re模块

      • fullmatch(正则表达式,字符串) - 判断整个字符串是否满足正则表达式描述的规制(完全匹配)
      • python提供正则表达式的方法:提供一个字符串,字符串内容是一个正则表达式,这个字符串的最前面需要加r
      fullmatch(正则表达式,字符串) 判断整个字符串是否满足正则表达式描述的规制(完全匹配)
      python提供正则表达式的方法 提供一个字符串,字符串内容是一个正则表达式,这个字符串的最前面需要加r
      python的正则表达式 r’正则’
      json的正则表达式 /正则/
    • 正则语法内容

      • 包括:匹配类符号、控制次数的符号、分组和分支、检测类符号
  3. 匹配类符号 - 约束字符串中某个位置上的字符是什么样的字符

    普通字符(字符) 在正则表达式表示字符本身符号就是普通符号(除了特殊符号以外的都是普通字符串)
    . 匹配任意一个字符
    \d 匹配任意一个数字字符
    \s 匹配任意一个空白字符,任何可以产生空白效果的符号(\t,\n)
    \D 匹配任意一个非数字字符
    \S 匹配任意一个非空白字符
    [字符集] 匹配字符集中的任意一个字符
    [^字符集] 匹配不在字符集中的任意一个字符

二 . 控制次数的符号

  1. 控制次数的符号的用法:匹配类符号次数
* 任意次数(0或者多次)
+ 至少一次(一次或者多次)
? 0次或者1次(有或者没有)
{N} N次
{M,N} M到N次
{M,} 至少M次
{,N} 最多N次
  1. 贪婪和非贪婪模式
    • 在匹配次数不确定的时候,匹配次数有贪婪和非贪婪两种模式
    • 默认是贪婪模式:*、+、[N]、[M,N]、[M,]、[,N]
    • 贪婪模式:如果多种匹配次数都可以匹配功能,最后取最大的次数进行匹配

三 . 分组和分支

  1. 分组 - ()
    • 整体操作:将正则的一部分用()括起来表示一个分组,然后整体控制次数
    • 重复匹配结果:在正则中用()添加分组,然后在正则用\M来重复前面第M个分组的匹配结果
    • 捕获:findall函数在正则表达式中有分组的时候,只获取分组匹配的结果
  2. 分支 - /
    • 正则1|正则2|正则3|……
    • 注意:如果是正则的部分要进行分支选择,需要将部分分支地方加()

四 . 检测类符号

  1. 检测类符号 - 检测符号所在的位置是否符合条件(必须是在匹配成功前提下才检测)

    • 检查\b所在的位置是否是单词边界

    • 单词边界:凡是可以将两个单词区分的符号都是单词边界

    • 注意:检测类符号不影响字符串长度

      单词边界 \b
      检测字符串开头 ^
      检测字符串结尾 $

    五 . 转义符号

    1. 转义符号
      • 在正则中本身具备特殊功能或者特殊意义的符号前加’\’,让他的功能销售,变成普通符号
    2. []也可以让独立存在有特殊意义的符号功能消失
      • 注意:^和 -在[]中的意义;[]在[]需要加\

    六 . re模块

    1. re模块中常用的函数及功能

      fullmatch(正则,字符串) 判断整个字符串是否满足正则描述的规制,如果不满足结果是None,满足返回匹配对象
      match(正则,字符串) 匹配字符串开头;如果不匹配返回None,否则返回匹配对象
      search(正则,字符串) 在整个字符串中查找第一个满足正则表达式的子串,如果找不到返回None,否则返回匹配对象
      findall(正则,字符串) 获取整个字符串所有满足正则的子串,返回一个列表
      finditer(正则,字符串) 获取整个字符串所有满足正则的子串,返回一个迭代器,迭代器中的元素是匹配对象
      sub(正则,字符串1,字符串2) 将字符串2中所有的满足正则的字符替换成字符串1
      split(正则,字符串) 将字符串中所有满足正则的子串作为切割点对字符串进行切割

    作业

    利用正则表达式完成下面的操作:

    一、不定项选择题

    1. 能够完全匹配字符串"(010)-62661617"和字符串"01062661617"的正则表达式包括( )

      A.r"\(?\d{3}\)?-?\d{8}"
      B. r"[0-9()-]+"
      C.r"[0-9(-)]*\d*"
      D.r"[(]?\d*[)-]*\d*"

    2. 能够完全匹配字符串"back"和"back-end"的正则表达式包括( )
      A. r'\w{4}-\w{3}|\w{4}'
      B. r'\w{4}|\w{4}-\w{3}'
      C.r'\S+-\S+|\S+'
      D. r'\w*\b-\b\w*|\w*'

    3. 能够完全匹配字符串"go go"和"kitty kitty",但不能完全匹配“go kitty”的正则表达式包括()
      A.r '\b(\w+)\b\s+\1\b'
      B. r'\w{2,5}\s*\1'
      C. r'(\S+) \s+\1'
      D.r'(\S{2,5})\s{1,}\1'

    4. 能够在字符串中匹配"aab",而不能匹配"aaab"和"aaaab"的正则表达式包括( )
      A. r"a*?b"
      B. r"a{,2}b"
      C. r"aa??b"
      D. r"aaa??b"

    二、编程题

    1.用户名匹配

    ​ 要求: 1.用户名只能包含数字 字母 下划线

    ​ 2.不能以数字开头

    ​ 3.⻓度在 6 到 16 位范围内

    from re import fullmatch,findall,split
    print('\n作业1')
    class reword:
        """一个正则表达式的作业的类"""
        def __init__(self,E):
            #初始化属性正则表达式
            self.E = E
    
        def fullF(self,str1):
            result = fullmatch(self.E, str1)
            return result
    
    username = reword(r'\D[\da-zA-Z_]{5,15}')
    print(username.fullF('S_sf6451'))
    
    
    1. 密码匹配

    ​ 要求: 1.不能包含!@#¥%^&*这些特殊符号

    ​ 2.必须以字母开头

    ​ 3.⻓度在 6 到 12 位范围内

    print('\n作业2')
    code = reword(r'[A-Za-z]\w{5,15}')
    print(code.fullF('aasdf65'))
    
    1. ipv4 格式的 ip 地址匹配
      提示: IP地址的范围是 0.0.0.0 - 255.255.255.255
    print('\n作业3')
    ip = reword(r'(([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|2[0-5]{2})')
    print(ip.fullF('123.255.56.21'))
    
    1. 提取用户输入数据中的数值 (数值包括正负数 还包括整数和小数在内) 并求和
    例如:“-3.14good87nice19bye” =====> -3.14 + 87 + 19 = 102.86
    
    print('\n作业4')
    class reFind(reword):
        """reE的衍生"""
        def findmethod(self,str1):
            result = findall(self.E, str1)
            return result
    
    sumnum = reFind(r'[+-]?\d+\.?\d*')
    print(sum([float(x) for x in sumnum.findmethod('-3.14good87nice19bye')]))
    
    1. 验证输入内容只能是汉字

      print('\n作业5')
      ishanzi = reword('[\u4e00-\u9fa5]+')
      print(ishanzi.fullF('打广告'))
      
    2. 匹配整数或者小数(包括正数和负数)

      print('\n作业6')
      isnum = reword('[+-]?\d+\.?\d*')
      print(isnum.fullF('+132.61'))
      
    3. 验证输入用户名和QQ号是否有效并给出对应的提示信息

      要求:
      用户名必须由字母、数字或下划线构成且长度在6~20个字符s之间
      QQ号是5~12的数字且首位不能为0

      print('\n作业7')
      class isNone(reword):
          """reword的关于判断是否空值的延伸"""
          def isnone(self,str1):
              if not str1:
                  print(f'{str1}不符合要求')
              else:
                  print(f'{str1}符合要求')
      
      isusername = isNone(r'[a-zA-Z_]{6,20}')
      isusername.isnone(isusername.fullF('a5464-a56SdfGA'))
      
      
      qqname = isNone('[1-9]\b{4,11}')
      qqname.isnone(qqname.fullF('2165169'))
      
    4. 拆分长字符串:将一首诗的中的每一句话分别取出来

      ​ poem = ‘窗前明月光,疑是地上霜。举头望明月,低头思故乡。’

      print('\n作业8')
      split1 = reFind('[\u4e00-\u9fa5]+')
      print(split1.findmethod('窗前明月光,疑是地上霜。举头望明月,低头思故乡。'))
      

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