day18正则表达式作业

总结

正则表达式
  1. 正则表达式

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

    • re模块
      • fullmatch(正则表达式,字符串) — 判断字符串是否满足正则表达式的规则(完全匹配)
      • python提供正则表达式的方法:提供一个字符串,字符串内容是一个正则表达式,这个字符串最前面需要加r
      • findall(正则表达式,字符串)
    • 正则语法内容
      • 匹配类符号、控制次数类符号、分组分支、检测类符号、阻止转义
  3. 匹配类符号 – 约束字符串中某个位置上的字符是什么样的字符

    • 普通符号
    • [字符集] – 匹配字符集中的任意一个字符
    • [^字符集] – 匹配不在字符集中的任意一个字符
  4. 控制次数

    • * --> 0或多次 eg:a*、[abc]*
    • + --> 1或多次 eg:a+、[abc]+
    • ? --> 0或1次 eg:a?、[±]?
    • {N} --> N次
      {M,N} --> M-N次
      {M,} --> 至少M次
      {,N} --> 最多N次
  5. 贪婪和非贪婪 – 在匹配次数不确定的时候,匹配次数有贪婪和非贪婪两种模式

    • 默认是贪婪模式:*、+、{M,N}、{M,}、{,N}
      贪婪模式:如果多种匹配次数都可以匹配成功,最后取最大的次数进行匹配
    • 非贪婪模式:*?、+?、{M,N}?、{M,}?、{,N}?
    # 贪婪  -- 取最多的次数
    print(search('a.+b','gdadkjbjfgbgt'))   # 'adkjbjfgb'
    
    # 非贪婪  -- 取最少的次数
    print(search('a.+?b','gdadkjbjfgbgt'))   # 'adkjb'
    
    # findall  -- 只要找到了就提出了
    print(findall(r'\d{2}','hi23hgh45hbjh12'))   # ['23', '45', '12']
    
  6. 分组和分支

    • 分组 - ()
      • 整体操作
      • 重复第几个操作就\N
      • 捕获
    • 分支 - |
      • 正则1|正则2|正则3|…
  7. 检测类符号 — 监测符号所在的位置是否符合条件(必须是在匹配成功的前提下才监测)

    • 单词边界 - \b

      • 监测\b所在的位置是否是单词边界。
        单词边界:凡是可以将两个单词区分开的符号都是单词边界,比如:字符串开头、字符串结尾、空白字符、标点符号等…
        注意:检测类符号不影响字符串长度
    • 监测字符串开头- ^

      监测字符串结尾- $

  8. 转移符合

    • 在正则中本身具备特殊功能或者特殊意义的符号前加’’,让其功能消失

      +、*、?、.、^、$

  9. re模块

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

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

一、不定项选择题
  1. 能够完全匹配字符串"(010)-62661617"和字符串"01062661617"的正则表达式包括( A,D)

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

  2. 能够完全匹配字符串"back"和"back-end"的正则表达式包括(A、B、C 、D )
    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、C、D)
    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"的正则表达式包括( B、C)
    A. r"a*?b"
    B. r"a{,2}b"
    C. r"aa??b"
    D. r"aaa??b"

二、编程题

1.用户名匹配

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

​ 2.不能以数字开头

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

name = 'as23_kj'
print(fullmatch(r'[a-zA-Z_][a-zA-Z\d_]{5,17}',name))
  1. 密码匹配

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

​ 2.必须以字母开头

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

passwork = 'adn345_'
print(fullmatch(r'[a-zA-Z][^!@#¥%^&*]{5,11}',passwork))
  1. ipv4 格式的 ip 地址匹配
    提示: IP地址的范围是 0.0.0.0 - 255.255.255.255
ip1 = '13.255.255.255'
print(fullmatch(r'((\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5]).){3}(\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5])', ip1))

  1. 提取用户输入数据中的数值 (数值包括正负数 还包括整数和小数在内) 并求和
例如:“-3.14good87nice19bye” =====> -3.14 + 87 + 19 = 102.86
str1 = '-3.14good87nice19bye'
new_str1 = split(r'[a-z]',str1)
sum1 = 0.0
for i in new_str1:
    if i != '':
        sum1 += float(i)
print(sum1)
  1. 验证输入内容只能是汉字

    print(fullmatch(r'[\u4e00-\u9fa5]+','暗杀计划'))
    
  2. 匹配整数或者小数(包括正数和负数)

    print(fullmatch(r'[+-]?(\d+|\d+.\d+)','0.3'))
    
  3. 验证输入用户名和QQ号是否有效并给出对应的提示信息

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

    print(fullmatch(r'[a-zA-Z\d_]{6,20}','sdch298_'))
    print(fullmatch(r'[1-9]\d{4,11}','1120232681'))
    
  4. 拆分长字符串:将一首诗的中的每一句话分别取出来

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

    poem = '窗前明月光,疑是地上霜。举头望明月,低头思故乡。'
    print(split(r'[,。]',poem))
    
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值