day18

一,匹配类符号

1.正则表达式

是一种可以让一些复杂的字符串问题变得简单的工具。

2.正则语法(通用)

1)re模块

fullmatch(正则表达式,字符串) - 判断整个字符串是否满足正则表达式描述的规则(完全匹配)

python提供正则表达式的方法:提供一个字符串,字符串内容是一个正则表达式,这个字符串的最前面需要加r

2)正则语法内容

包括:匹配类符号、控制次数的符号、分组和分支、检测类符号

3.匹配类符号 - 约束字符串中某个位置上的字符是什么样的字符

1)普通符号(字符)

在正则表达式中表示字符本身的符号就是普通符号(除了特殊符号以外的都是普通符号)

from re import fullmatch
# r'abc'  - 表示一个字符串有三个字符,分别是a、b和c
result = fullmatch(r'abc', 'abc')
print(result)

2). - 点表示匹配任意一个字符

# r'.bc' - 表示一个字符串,有3个字符,第一个字符是任意字符,第2个和第3个分别是b和c
result = fullmatch(r'.bc', '好bc')
print(result)

3)\d - 匹配任意一个数字字符

from re import fullmatch
result1 = fullmatch(r'x\dy', 'x7y')
print(result1)

4)\s - 匹配一个空白字符

空白字符:任何可以产生空白效果的符号,例如 空格、\t、\n

5)\D - 匹配任意一个非数字字符

6)\S - 匹配一个非空白字符

7)[字符集] - 匹配字符集中的任意一个字符

"""
[mnab] - 匹配m或者n或者a或者b
[\dmn]、[m\dn]  - 匹配任意数字或者m或者n
[\d\s]   -  匹配任意数字或者任意空白
[1-9]   -  匹配1到9中任意数字
[0-9]   - 和\d效果一样
[a-z]   -  匹配任意一个小写字母
[1-5a-z]  - 匹配数字1到5或者任意小写字母
[A-Za-z]  -  匹配任意一个字母
[\u4e00-\u9fa5]  -  匹配任意一个中文
[\u4e00-\u9fa5wp]  -  匹配任意一个中文或者w或者p
"""
result = fullmatch(r'x[Mn3+]y', 'xMy')
print(result)result = fullmatch(r'x[\u4e00-\u9fa5\dwp]y', 'x3y')
print(result)

8)[ ^字符集 ] - 匹配不在字符集中的任意字符

二、控制次数的符号

控制次数符号的用法:匹配类符号次数

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

"""
a*    -  a出现0次或者多次
\d*   -  \d出现0次或者多次(任意数字出现0次或者多次)
[abc]*   -  [abc]出现0次或者多次
"""

2.+ - 至少一次(1次或多次)

print(fullmatch(r'xa+y', 'xy'))     # None
print(fullmatch(r'xa+y', 'xaaaaay'))
print(fullmatch(r'x[\u4e00-\u9fa5]+y', 'x函数y'))

3.? - 0次或者1次

# 277、-728、+723
print(fullmatch(r'[+-]?[1-9]\d\d', '810'))
print(fullmatch(r'❤?xy', '❤xy'))

4.{}

{N} - N次

{M,N} - M到N次

{M,} - 至少M次

{,N} - 最多N次

print(fullmatch(r'1[3-9]\d{9}', '13892839283'))
print(fullmatch(r'123a{4}', '123aaaa'))
print(fullmatch(r'123a{2,4}', '123aaa'))
print(fullmatch(r'123a{2,}', '123aaaaaaaa'))# 练习:写一个正则表达式可以匹配任意一个整数字符串
# 123、23、1、+23、-23、100,2, 2312312  - 合法
# 0002、23s、+-23、01  -  不合法
print(fullmatch(r'[+-]?[1-9]\d*', '10'))

5.贪婪和非贪婪模式

在匹配次数不确定的时候,匹配次数有贪婪和非贪婪两种模式

1)

默认是贪婪模式:*、+、{M,N}、{M,}、{,N}

贪婪模式:如果多种匹配次数都可以匹配成功,最后取最大的次数进行匹配

2)

非贪婪模式:*?、+?、{M,N}?、{M,}?、{,N}?

# 贪婪
print(search('a.+b', '上访户大富豪amnbxybmnhjb按实际符合sdf'))      # 'amnbxyb'# 非贪婪
print(search('a.+?b', '上访户大富豪amnbxybmnhjb按实际符合sdf'))     # 'amnb'print(search('a.+b', '上访户大富豪axyb按实际符合sdf'))
print(search('a.+?b', '上访户大富豪axyb按实际符合sdf'))

三、分组和分支

1.分组 - ()

1)整体操作:将正则的一部分用()括起来表示一个分组,然后整体控制次数

2)重复匹配结果:在正则中用()添加分组,然后在正则用 \N 来重复前面第N个分组的匹配结果

3)捕获:findall函数在正则表达式中有分组的时候,只获取分组匹配到的结果

2.分支 - |

正则1|正则2|正则3|…

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

四、检测类符号

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

1)单词边界 - \b

检测\b所在的位置是否是单词边界。

单词边界:凡是可以将两个单词区分开的符号都是单词边界,比如:字符串开头、字符串结尾、空白字符、标点符号

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

2)检测字符串开头 - ^

3)检测字符串结尾 - $

五、转义符号

1.转义符号

在正则中本身具备特殊功能灹特殊意义的符号前加’ \ ',让他的功能消失,变成普通符号

print(fullmatch(r'\d\d\.\d\d', '12.34'))
print(fullmatch(r'\d\+\d', '2+4'))
print(fullmatch(r'abc\\d', 'abc\d'))
print(fullmatch(r'\(\d\d\)', '(23)'))

2.[]也可以让独立存在有特殊意义的符号功能消失

+、*、?、.、^、$、|等

注意:^和-在[]中的意义;[]在[]需要加\

print(fullmatch(r'\d\d[.+*?\]$^-]\d\d', '12]34'))

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

from re import fullmatch, match, search, findall, finditer, sub, split"""
fullmatch(正则, 字符串)  - 完全匹配;判断整个字符串是否正则描述的规则,如果不满足结果是None,满足返回匹配对象
match(正则, 字符串) - 匹配字符串开头;如果不匹配返回None,否则返回匹配对象
search(正则, 字符串)  -  在整个字符串中查找第一个满足正则表达式的子串,如果找不到返回None,否则返回匹配对象
findall(正则, 字符串)  -  获取整个字符串中所有满足正则的子串,返回一个列表 (注意分组问题)
finditer(正则, 字符串)  -  获取整个字符串中所有满足正则的子串,返回一个迭代器,迭代器中的元素是匹配对象
sub(正则, 字符串1, 字符串2)  -  将字符串2中所有满足正则的字串全部替换成字符串1
split(正则, 字符串)  - 将字符串中所有满足正则的子串作为切割点对字符串进行切割
"""print(fullmatch(r'\d{3}', '123'))
print(match(r'\d{3}', '123阿萨德发234234asfas'))
print(search(r'\d{3}', '阿萨892德发208asf1023as'))
print(findall(r'\d{3}', '阿萨892德发208asf1023as'))
print(findall(r'[a-z](\d{3})', '阿萨892德发208asf1023as'))str1 = 'how are you? i am fine! thank you! and you?'
result = str1.replace('you', 'me')
print(result)result = sub(r'you|i', 'me', str1)
print(result)str1 = '阿萨892德发208asf1023as'
result = sub(r'\d', '*', str1)
print(result)str1 = 'how are you? i am fine! thank you! and you?'
print(str1.split('you'))
print(split(r'you', str1))str1 = 'hsj+23g-shdf-ahsf-水电费+234'
print(split(r'[+-]', str1, 2))

作业

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

一、不定项选择题

  1. 能够完全匹配字符串"(010)-62661617"和字符串"01062661617"的正则表达式包括( A B 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)
    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'

    1. 能够在字符串中匹配"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 位范围内

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

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

​ 2.必须以字母开头

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

print(fullmatch(r'[A-Za-z][^!@#¥%^&*]{5,11}', 'A234567'))
  1. ipv4 格式的 ip 地址匹配
    提示: IP地址的范围是 0.0.0.0 - 255.255.255.255

  1. 提取用户输入数据中的数值 (数值包括正负数 还包括整数和小数在内) 并求和
例如:“-3.14good87nice19bye” =====> -3.14 + 87 + 19 = 102.86
from re import fullmatch, findall
result = findall(r'[+-]?\d{1,}\.\d{1,}|[+-]?\d{1,}', '-3.14good87nice19bye')
b = []
for x in result:b.append(float(x))
print(sum(b))
  1. 验证输入内容只能是汉字

    from re import fullmatch, findall
    print(fullmatch(r'[\u4e00-\u9fa5]{1,}', '疾风亚索跑得快'))
    
  2. 匹配整数或者小数(包括正数和负数)

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

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

  4. 拆分长字符串:将一首诗的中的每一句话分别取出来

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

day18总结和作业相关推荐

  1. English Learning - L3 作业打卡 Lesson3 Day18 2023.5.22 周一

    English Learning - L3 作业打卡 Lesson3 Day18 2023.5.22 周一 引言

  2. 老男孩Day18作业:后台用户管理

    一.作业需求:1.用户组的增删改查2.用户增删该查- 添加必须是对话框- 删除必须是对话框- 修改,必须显示默认值3.比较好看的页面二.博客地址:https://www.cnblogs.com/cat ...

  3. 基于python的作业管理系统_python day18 作业 Django 开发主机管理系统

    思路是这样的 思路: 1. 用SQLAlhemy 添加信息表和 用户表 2. 登陆时获取用户的用户名密码. 去数据库获取数据,并取得数据, 对比判断. 3. 查看所有主机,首先判断是否登陆. 如果登陆 ...

  4. Linux七大项目作业详细步骤

    Author:lp Date:2020-12-9 目录 网络服务 软件包管理 服务与进程管理 DHCP作业 DNS作业 HTTPD SAMBA配置 下面步骤是创建新的虚拟机,如果不想创建也可在老的虚拟 ...

  5. 小甲鱼课后作业_【第九讲勤思课后作业】二元一次方程组的解法巩固加油站

    ☝点击蓝字关注我们 二元一次方程组解法 巩固|第9讲 二元一次方程组解法:核心是消元 两种消元方法:代入消元法和加减消元法 技巧类解法:系数轮换法和换元法 以下为第9讲勤思班作业的视频讲解 第九讲的巩 ...

  6. LeetCode简单题之在既定时间做作业的学生人数

    题目 给你两个整数数组 startTime(开始时间)和 endTime(结束时间),并指定一个整数 queryTime 作为查询时间. 已知,第 i 名学生在 startTime[i] 时开始写作业 ...

  7. 作业函数的定义与调用

    作业函数的定义与调用 在 OneFlow 中,将训练.预测任务封装在一个函数中,统称为作业函数(job function),作业函数联系用户的业务逻辑与 OneFlow 管理的计算资源. 在 OneF ...

  8. 华东理工大学计算机应用基础,最新华东理工大学计算机应用基础网上作业及全部答案...

    精品文档 华东理工大学计算机应用基础网上作业及全部答案 2012计算机应用基础答案: 一.选择题 1.文件夹是用来对应用程序.文件进行分组的,以下说法中()正确.答:一个文件夹内可以包含文件.应用程序 ...

  9. 《小团团团队》第五次作业:项目需求分析改进与系统设计

    项目 内容 这个作业属于哪个课程 任课教师博客主页链接 这个作业的要求在哪里 实验九 团队作业5-团队项目需求改进与系统设计 团队名称 小团团团队 作业学习目标 (1)掌握面向对象需求分析方法:(2) ...

最新文章

  1. pip 无法卸载 pillow 解决方案 Not uninstalling pillow at /usr/lib/python3/dist-packages
  2. Notification和KVO有什么不同
  3. 【青少年编程】【四级】创意画图
  4. 通过一个实际案例,彻底搞懂 HashMap!
  5. linux中gcc是什么指令,Linux gcc常用命令
  6. 统信软件用一年时间跨越式发展说明了一件事
  7. [XSY]Illyasviel的图游戏(博弈论)
  8. 谈谈运维人员谨慎操作系统环境和管理
  9. react-demo
  10. Android -- Layout布局文件里的android:layout_height等属性为什么会不起作用?
  11. Endnote x7怎么在word中显示的处理方法
  12. 数据库防火墙数据库加密与脱敏数据泄露防护
  13. OpenCV 安装配置 Jupyter Notebook
  14. pychart绘制中国地图用英文省名
  15. python 日程管理程序_729. 我的日程安排表(Python)
  16. Introduction的Advice的实现
  17. springboot+easypoi excel表格多个sheet导出
  18. rockyLinux 初体验PostgreSQL15详细安装教程
  19. android如何编程红外遥控,全志A20[android教程]-红外遥控器调试
  20. Java JSON格式简介说明

热门文章

  1. LabVIEW 2020入门(一)
  2. FAQ翻译 第一章 C++蓝图
  3. 计算机运行时删除桌面上的应用程序图标,删除windows桌面上某个应用程序的图标,意味着什么...
  4. suse enterprise linux 10 安装及配置svn(使用svnserve)
  5. u盘误删除恢复,迅龙数据恢复
  6. Visual Studio Code+drawio扩展插件的安装和使用,免费的软件构图神器
  7. 如何实现在线数据的离线浏览和修改
  8. 基于Kotlin的安卓音乐播放器
  9. 高清视频转换器,任意格式互转方法!
  10. python网络嗅探