Python正则表达式

Python正则表达式

1.匹配符号

  1. re模块

re模块是python提供的专门用支持正则表达式的一个模块

  1. 正则语法

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

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

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

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

  1. 字符

    1. 普通字符(普通符号)
      在正则除了有特殊功能或者特殊意义以外的符号;
      普通字符在正则中表示这个符号本身。

    2. . – 匹配任意一个字符
      注意:一个.只能匹配一个任意字符

    3. \d – 匹配任意一个数字字符

    4. \s - 匹配任意一个空白字符
      空白字符:空格、回车(\n)、制表符(\t)

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

    1. [字符集] - 匹配字符集中任意一个字符
      注意:一个[]只能匹配一个字符
      [多个普通字符] - 例如:[abc],可以匹配a或者b或者c
      [包含\开头的特殊符号的字符集] - 例如:[\dabc],可以匹配任意数据或者a或者b或者c

    [包含减号在两个字符之间的字符集] - 这个时候的减号表示谁到谁(注意:减号前面的字符的编码必须小于减号后面的)
    例如:
    [a-z] - 匹配任意一个小写字母
    [a-d] - 匹配a、b、c、d中的任意一个字符
    [A-Z] - 匹配任意一个大写字母
    [1-9] - 匹配1到9中任意一个数字字符
    [\u4e00-\u9fa5] - 匹配任意一个中文字符
    [a-zA-Z]、[A-Za-z] - 匹配任意一个字母
    [a-z123] - 匹配任意一个小写字母,或者1或者2或者3
    [a-z\d] - 匹配任意一个小写字母或者任意一个数字

    1. [^字符集 - 匹配任意一个不在字符集任意一个字符
      [^abc - 匹配除了a、b、c以外的任意一个字符
      [^a-z - 匹配除了小写字母以外的任意一个字符

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

2.检测类符号

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

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

  1. \b - 检测是否是单词边界
    单词边界 - 能够区分出两个不同单词的符号都属于单词边界,例如:空白、标点符号、字符串开头、字符串结尾
# findall(正则表达式, 字符串)   -   获取字符串中所有满足正则表达式的子串
str1 = '12ksksj78ss 34抗生素,89 试7试看90 56 江苏省23'
result1 = findall(r'\d\d', str1)
print(result1)  
# ['12', '78', '34', '89', '90', '56', '23']

result2 = findall(r'\d\d\b', str1)
print(result2)
# ['89', '90', '56', '23']

result3 = findall(r'\b\d\d\b', str1)
print(result3)
# ['89', '56']
  1. \B - 检测是否是非单词边界

    result3 = findall(r'\d\d\B', str1)
    print(result3)
    # ['12', '78', '34']
    
  2. ^ - 检测是否是字符串开头

    re_str = r'^\d\d'
    print(fullmatch(re_str, '12'))
    # <re.Match object; span=(0, 2), match='12'>
    print(findall(r'^\d\d',  str1))
    # ['12']
    
  3. $ - 检测是否是字符串结尾

    
    

3.匹配次数

  1. 匹配0次或者多次(任意次数)
    用法:匹配类符号*
    a* - 匹配任意多个a
    \d* - 匹配任意多个数字字符
print(fullmatch(r'a*b', 'b'))
print(fullmatch(r'a*b', 'aab'))
print(fullmatch(r'a*b', 'aaaaaaab'))
print(fullmatch(r'\d*b', '245899b'))
print(fullmatch(r'[abc]*x', 'aabccax'))
  1. ​ + --匹配1次或多次(至少一次)
print(fullmatch(r'a+b', 'b'))     # None
print(fullmatch(r'a+b', 'ab'))
print(fullmatch(r'a+b', 'aaaaab'))
  1. ​ ? - 匹配0次或1次

    re_str = r'[-+]?[1-9]\d'
    print(fullmatch(re_str, '-12'))
    print(fullmatch(r'a?b', 'b'))
    print(fullmatch(r'a?b', 'ab')
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python正则表达式是一种强大的字符串处理工具,它可以用于在文本中查找、替换和提取特定模式的字符串。在Python中使用正则表达式,需要先导入`re`模块。 下面是一个简单的示例代码,演示了如何使用正则表达式字符串中匹配特定的模式: ```python import re # 定义一个待匹配的字符串 string = "Hello, my email address is example@example.com" # 定义一个正则表达式模式,用于匹配邮箱地址 pattern = r'\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,}\b' # 使用re模块的findall()方法进行匹配 matches = re.findall(pattern, string) # 输出匹配的结果 print(matches) ``` 运行以上代码,输出结果会是`['example@example.com']`,即匹配到了字符串中的邮箱地址。 在正则表达式中,可以使用一些特殊字符和元字符来构建匹配模式。例如,`r'\b'`表示单词边界,`[A-Za-z0-9._%+-]`表示匹配字母、数字、点、下划线、百分号、加号和减号等字符。 除了匹配字符,还可以使用一些特殊的元字符来表示数量和位置。例如,`+`表示前面的字符出现一次或多次,`*`表示前面的字符出现零次或多次,`{2,}`表示前面的字符出现至少两次。 以上只是简单介绍了Python正则表达式的基本用法,实际上正则表达式还有很多高级用法和特性。你可以参考Python官方文档中关于`re`模块的详细说明来深入学习和理解正则表达式的使用方法。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值