day16-正则表达式

正则表达式

re模块引入

re模块是python一共的专门支持这个则表达式的一个模块

fullmatch函数:

fullmatch(正则表达式,字符串) - 让正则表达式和指定字符串惊醒完全匹配,如果匹配失败返回None;

正则语法

正则表达式 - 正则表达式是一个让字符串复杂问题变得简单的工具

写正则表达式的主要工作:用正则符号描述清楚相关字符串的规则

1)普通字符(普通符号)

在正则除了有特殊功能或者特殊意义以外的符号

普通字符在正则中表示这个符号本身

python正则表示方式:r’正则表达式’

js的正则:/正则表达式/

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

re_str = r'a.c'
print(fullmatch(re_str, 'abc'))

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

re_str = r'a\d\dc'
print(fullmatch(re_str, 'a12c'))

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

空白字符:制表符(\t)、空格、回车(\n)

re_str = r'a\sb'
print(fullmatch(re_str, '''a
b'''))

5)\w - 匹配任意一个字母、数字或者下划线(不好用

6)

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

\S - 匹配任意一个非空字符

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

注意:一个[]只能匹配一个字符

[多个普通字符] - [abc]可以匹配a或者b或者c

[包含\开头的特殊符号的字符集] - [\dabc],可以匹配任意数字或者a或者b或者c

[包含减号在两个字符之间的字符集] - 这个时候的减号表示谁到谁

注意:减号前面的字符编码必须小于减号后面的

例如:

[a-z] - 任意一个字母

[a-d] - 匹配abcd中任意一个字符

[A-Z] - 匹配任意一个大写字母

[1-9] - 匹配1到9中任意一个数字字符

[\u4e00-\u9fa5] - 匹配任意一个中文字符

[a-zA-Z]、[A-Za-z] - 任意一个字母

[a-z123] - 匹配任意一个小写字母,或者1或者2或者3

re_str = r'a[xym]b'
print(fullmatch(re_str, 'amb')) 	# axb ayb amb

8)[^字符集] - 匹配任意一个不在字符集任意一个字符

[^abc] - 匹配除了a、b、c以外的任意一个字符

[^a-z] - 匹配除了小写字母以外的任意一个字符

注意:[]中的-和^只有放在指定位置的时候才有特殊功能,否则在[]中就是一个普通的符号

检测类符号

检测类符号的存在不影响被匹配的字符串长度,它的作用是在匹配成功的前提下检测符号所在的位置是否符合要求

检测类符号的用法:先去掉检测类符号,看是否能匹配成功,如果失败整个正则匹配失败。如果成功再来看检测类符号所在的位置是否符合要求

  1. \b - 检测是否是单词边界

单词边界 - 能够区分出两个不同单词的符号都属于单词边界,例如:空白、标点符号、字符串开头、字符串结尾

  1. \B - 检测是否是非单词边界

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

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

匹配次数

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

用法:匹配类符号*

a* - 匹配任意多个a

\d* - 匹配任意多个数字字符

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

3.? - 匹配0次或1次

4.{}

{N} - 匹配N次

{M,N} - 匹配M到N次

{,N} - 匹配最多N次

{M,} - 匹配最少M次

5.贪婪和非贪婪

在匹配次数不确定的时候,匹配模式分为贪婪和非贪婪两种,默认是贪婪模式

在匹配成功的前提下,贪婪是匹配次数选最多的那个次数;非贪婪是匹配次数最少的那个次数

*、+、?、{M,N}、{M,}、{,N} - 贪婪的

*?、+?、??、{M,N}?、{M,}?、{,N}? - 非贪婪的

分组和分支

1.() - 分组

作用1:将()中的内容作为一个整体,进行整体相关操作,例如,整体控制次数

作用2:通过’\M’重复前面第M个分组匹配到的结果,M从1开始

作用3:捕获

str1 = ‘23abc23’

2.| - 分支

正则1|正则2 - 先用正则1进行匹配,如果成功就直接匹配成功,如果匹配失败再用正则2进行匹配

3.转义符号

在特殊符号前加\,让符号的功能消失,变成一个普通符号

若果是独立存在有特殊功能的符号,将符号放入[]中其功能也会自动消失

re模块

  1. re.compile
re_obj = re.compile(r'')
re_obj.fullmatch('')
  1. fullmatch(正则表达式,字符串) - 让正则表达式和整个字符串进行匹配(完全匹配),匹配失败返回None,匹配成功返回匹配对象

match(正则表达式,字符串) - 匹配字符串开头

result 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值