3.9总结、作业-正则表达式

3.9总结、作业-正则表达式

一、匹配类符号

  1. 普通符号(字符)
    在正则表达式中表示字符本身的符号就是普通符号(除了特殊符号以外都是普通符号)
    result = fullmatch(r’abc’, ‘abc’)
    r’abc’ - 表示一个字符串有三个字符,分别是a.b和c
    print(result)
  1. . - 匹配任意一个字符
    r’.bc’ - 表示一个字符串有三个字符,第一个字符是任意字符,第2个和第3个分别是b和c
    result = fullmatch(r’.bc’, ‘好bc’)
    print(result)

  2. \d - 匹配任意一个数字字符
    result = fullmatch(r’x\dy’, ‘x9y’)
    print(result)

  3. \s - 匹配任意一个空白字符
    空白字符:任何可以产生空白效果的符号,例如: 空格、\t、\n
    result = fullmatch(r’x\sy’, ‘x\ny’)
    print(result)

  4. \D - 匹配任意一个非数字字符
    result = fullmatch(r’x\Dy’, ‘x3y’)
    print(result) # None

  5. \S - 匹配任意一个非空白字符
    result = fullmatch(r’a\Sb’, ‘aeb’)
    print(result)

  1. [字符集] - 匹配字符集中的任意一个字符
    result = fullmatch(r’x[abc]y’, ‘xay’)
    print(result)

  2. [^字符集] - 匹配不在字符集中的任意一个字符

二.控制次数的符号

  1. *- 任意次数(0次或者多次)

  2. ±至少一次(1次或多次)

  3. ?-0次或者1次

  4. {}

    {N} - N次
    {M,N} - M到N次
    {M,} - 至少M次
    {,N} - 最多N次

三.贪婪和非贪婪

默认是贪婪模式:*、+、{M,N}、{M,}、{,N}
贪婪次数:如果多种匹配次数都可以匹配成功,最后取最大的次数进行匹配

非贪婪模式: *? 、+?、 {M,N}?、 {M,}?、 {,N}?
贪婪次数:如果多种匹配次数都可以匹配成功,最后取最小的次数进行匹配

四.分组和分支

1.分组:

1)将正则的一部分用()括起来表示一个分组,然后整体控制次数
2)重复匹配结果:在正则中用()添加分组,然后在正则中用’\M’来重复前面第N个分组的匹配结果
3)捕获: findall函数在正则表达式中有分组的时候,只获取分组匹配到的结果

2.分支:

正则1|正则2|正则3|…
注意:如果是正则的部分要进行分支选择,需要将部分分支地方加()

五.检测类符号

1单词边界 - \b

检测\b所在的位置是否是单词边界
单词边界:凡是可以将两个单词区分开的符号都是单词边界,比如:字符串开头,字符串结尾,空白字符,标点符号!

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

2 检测是否是字符串开头 - ^

3 检测是否是字符串结尾 - $

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

fullmatch(正则,字符串) - 判断整个字符串是否正则描述的规则,如果不满足结果是None,满足返回匹配对象

match(正则,字符串) - 匹配字符串开头;如果不匹配返回None,否则返回匹配对象

search(正则,字符串) - 在整个字符串中查找第一个满足正则表达式的子串,如果找不到返回None,否则返回匹配对象

findall(正则,字符串) - 获取整个字符串中所有满足正则的子串,返回一个列表(注意分组问题)

finditer(正则,字符串) - 获取整个字符串中所有满足正则的子串,返回一个迭代器,迭代器中的元素是匹配对象

sub(正则,字符串1,字符串2) - 将字符串2中所有满足正则的字符串全部替换成字符串1

split(正则,字符串) - 将字符串中所有满足正则的子串作为切割点对字符串进行切割

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

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

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

二、编程题

1.用户名匹配

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

​ 2.不能以数字开头

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

print(fullmatch(r'[A-Za-z_][A-Za-z0-9_]{5,15}', 'f312_535'))
  1. 密码匹配

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

​ 2.必须以字母开头

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

print(fullmatch(r'[A-Za-z][^!@#¥%^&*]{5,11}', 'j4324j55'))
  1. ipv4 格式的 ip 地址匹配
    提示: IP地址的范围是 0.0.0.0 - 255.255.255.255
r_str = r'([0-9]|[1-9]\d|1\d\d|2[0-4][0-9]|25[0-5])\.([0-9]|[1-9]\d|1\d\d|2[0-4][0-9]|25[0-5])\.([0-9]|[1-9]\d|1\d\d|2[0-4][0-9]|25[0-5])\.([0-9]|[1-9]\d|1\d\d|2[0-4][0-9]|25[0-5])'
str1 = '32.255.255.255'
print(fullmatch(r_str, str1))
  1. 提取用户输入数据中的数值 (数值包括正负数 还包括整数和小数在内) 并求和
例如:“-3.14good87nice19bye” =====> -3.14 + 87 + 19 = 102.86
r_str = r'[-]?\d\.\d+|[-]?\d+'
str1 = '-3.14good87nice19bye'
result = findall(r_str, str1)
sum1 = 0
for i in result:
	sum1 += float(i)
print(sum1)
  1. 验证输入内容只能是汉字

    r_str = r'[\u4e00-\u9fa5]+'
    str1 = input('请输入:')
    print(fullmatch(r_str, str1))
    
  2. 匹配整数或者小数(包括正数和负数)

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

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

    r1_str = r'[a-zA-Z0-9_]{6,20}'
    r2_str = r'[1-9]\d{4,11}'
    str1 = input('请输入用户名:')
    str2 = input('请输入QQ号:')
    if not fullmatch(r1_str, str1):
    	print('用户名无效')
    if not fullmatch(r2_str, str2):
    	print('QQ号无效')
    
  4. 拆分长字符串:将一首诗的中的每一句话分别取出来

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

    poem = '窗前明月光,疑是地上霜。举头望明月,低头思故乡。'
    
    result = findall(r'([\u4e00-\u9fa5]{5})[,。]', poem)
    for i in result:
    	print(i)
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值