正则表达式就是匹配字符串内容的一种规则。

字符组:

  [0123456789] 表示0-9这个范围内的任意一个数字都可以与之匹配,简写为[0-9]

  [a-z] 表示匹配所有的小写字母

  [A-Z] 表示匹配所有的大写字母

  [0-9a-zA-Z]  表示可以匹配数字和大小写字母

字符:

  .       匹配除换行符以外的任意字符

  \w    匹配字母或数字或下划线

\W    匹配非字母或数字或下划线

  \s     匹配任意的空白符

  \S     匹配非空白符

  \d   匹配数字

  \D     匹配非数字

  \n      匹配一个换行符

  \t  匹配一个制表符

  \b  匹配一个单词的结尾

  ^  匹配字符串的开始

  $  匹配字符串的结尾

  a|b 匹配字符a或字符b

  ()  匹配括号内的表达式,也表示一个组

  [^...] 匹配除了字符组中字符的所有字符

量词:

  *    重复零次或更多次

  +    重复一次或更多次

  ?  重复零次或一次

  {n}  重复n次

  {n,}  重复n次或更多次

  {n,m} 重复n到m次

转义符\:

  在正则表达式中,有很多有特殊意义的是元字符,比如\d和\s等,如果要在正则中匹配正常的"\d"而不是"数字"就需要对"\"进行转义,变成'\\'。

  在python中,无论是正则表达式,还是待匹配的内容,都是以字符串的形式出现的,在字符串中\也有特殊的含义,本身还需要转义。所以如果匹配一次"\d",字符串中要写成'\\d',那么正则里就要写成"\\\\d",这样就太麻烦了。这个时候我们就用到了r'\d'这个概念,此时的正则是r'\\d'就可以了。

贪婪匹配: 

贪婪匹配:在满足匹配时,匹配尽可能长的字符串,默认情况下,采用贪婪匹配

  *? 重复任意次,但尽可能少重复

  +? 重复1次或更多次,但尽可能少重复

  ?? 重复0次或1次,但尽可能少重复

  {n,m}? 重复n到m次,但尽可能少重复

  {n,}? 重复n次以上,但尽可能少重复

re模块下的常用方法:

findall : 返回所有满足匹配条件的结果,放在列表里

  1. import re
  2. ret = re.findall('e','nice to meet you')
  3. print(ret) # ['e', 'e', 'e']

search : 函数会在字符串内查找模式匹配,只到找到第一个匹配然后返回一个包含匹配信息的对象,该对象可以 通过调用group()方法得到匹配的字符串,如果字符串没有匹配,则返回None。

  1. import re
  2. ret = re.search('e','nice to meet you')
  3. print(ret.group()) # e
  4. ret = re.search('a','nice to meet you')
  5. print(ret) # None

match : 同search,不过仅仅只是在字符串开始处进行匹配

  1. import re
  2. ret = re.match('n','nice to meet you')
  3. print(ret.group()) # n
  4. ret = re.match('t','nice to meet you')
  5. print(ret) # None

split :分割

  1. ret = re.split('[ab]','abcd')
  2. print(ret) # ['', '', 'cd'] 先按'a'分割得到''和'bcd',在对''和'bcd'分别按'b'分割
  3. ret = re.split('ab','abcd')
  4. print(ret) # ['', 'cd'] 按ab整体进行切割,左边'',右边'cd'
  5.  
  6. ret = re.split('b','abcd')
  7. print(ret) # ['a', 'cd']
  8.  
  9. ret = re.split('[bc]','abcd')
  10. print(ret) # ['a', '', 'd']
  11. ret = re.split('[d]','abcd')
  12. print(ret) # ['abc', '']

split

sub : 替换

  1. ret = re.sub('\d','L','gh2cj4df89ab')
  2. print(ret) # ghLcjLdfLLab 将数字替换成'L' ,最后那个参数不写,则默认全部替换
  3. ret = re.sub('\d','L','gh2cj4df89ab',1)
  4. print(ret) # ghLcj4df89ab 最后那个参数是1表示只替换1个,从左边开始找
  5. ret = re.sub('h','L','gh2cjh4df89ab')
  6. print(ret) # gL2cjL4df89ab

sub

subn :  替换,返回元组

  1. ret = re.subn('\d','L','gh2cj4df89ab')
  2. print(ret) # ('ghLcjLdfLLab', 4) 将数字替换成'L' ,返回元组 (替换后的字符串,替换了多少次) 最后那个参数不写,则默认全部替换
  3. ret = re.subn('\d','L','gh2cj4df89ab',3)
  4. print(ret) # ('ghLcjLdfL9ab', 3) 只替换了3次

subn

compile : 编译

  1. import re
  2. obj = re.compile('\d{3}') #将正则表达式编译成为一个 正则表达式对象,规则要匹配的是3个数字
  3. re = obj.findall('ab125djj5671sjjk') #正则表达式对象调用findall,参数为待匹配的字符串
  4. print(re) # ['125', '567']

finditer : 返回一个存放匹配结果的迭代器

  1. import re
  2. ret = re.finditer('\d','hgd2dff6s4av1')
  3. print(ret) # <callable_iterator object at 0x000001FC67470160>
  4. print(next(ret).group()) # 2 查看第一个结果
  5. print(ret.__next__().group()) # 6 查看第二个结果
  6. print([i.group() for i in ret]) # ['4', '1'] 查看剩余的结果

finditer

findall的优先级查询:

  1. import re
  2. ret = re.findall('www.(baidu|cnblogs).com','www.cnblogs.com')
  3. print(ret) # ['cnblogs'] 这是因为findall会优先把匹配结果组里内容返回,如果想要匹配结果,取消权限即可
  4. ret = re.findall('www.(?:baidu|cnblogs).com','www.cnblogs.com')
  5. print(ret) # ['www.cnblogs.com']

split的优先级查询:

  1. import re
  2. ret = re.split('\d+','lucy2lilei3jim4lily')
  3. print(ret) # ['lucy', 'lilei', 'jim', 'lily']
  4. ret = re.split('(\d+)','lucy2lilei3jim4lily')
  5. print(ret) # ['lucy', '2', 'lilei', '3', 'jim', '4', 'lily']
  6. #在匹配部分加上()之后所切出的结果是不同的,
  7. #没有()的没有保留所匹配的项,但是有()的却能够保留了匹配的项,
  8. #这个在某些需要保留匹配部分的使用过程是非常重要的。
  1.  

python常用模块----re模块的更多相关文章

  1. Python常用内建模块

    Python常用内建模块 datetime 处理日期和时间的标准库. 注意到datetime是模块,datetime模块还包含一个datetime类,通过from datetime import da ...

  2. python常用内建模块 collections,bs64,struct,hashlib,itertools,contextlib,xml

    #  2  collections 是Python内建的一个集合模块,提供了许多有用的集合类. # 2.1 namedtuple #tuple可以表示不变集合,例如,一个点的二维坐标就可以表示成: p ...

  3. Python 常用内建模块(time ,datetime)

    1,在Python中,与时间处理有关的模块就包括:time,datetime以及calendar. 2,在Python中,通常有这几种方式来表示时间:1)时间戳 2)格式化的时间字符串 3)元组(st ...

  4. python常用命令—查看模块所在位置

    环境:ipython3 交互式解释器 语法: import 模块名 模块名.__file__ 功能: 查看模块的所在位置 例:

  5. python常用函数及模块

    原文来源于博客园和CSDN 1.计算函数 abs()--取绝对值 max()--取序列最大值,包括列表.元组 min()--取序列最小值 len()--取长度 divmod(a,b)---取a//b除 ...

  6. Python 常用内建模块(os, sys,random)

    一.os 模块 1,操作系统与环境变量 import osprint(os.name) #操作系统类型,如果是posix 说明系统是linux unix 或 mac os x :如果是nt 就是win ...

  7. python常用内建模块——datetime

    datetime是python处理日期和时间的标准库. 获取当前日期和时间 >>>from datetime import datetime >>>now = da ...

  8. collections(python常用内建模块)

    文章来源:https://www.liaoxuefeng.com/wiki/897692888725344/973805065315456 collections collections是Python ...

  9. Python常用内建模块和第三方库

    目录 内建模块 1  datetime模块(处理日期和时间的标准库) datetime与timestamp转换 str与datetime转换 datetime时间加减,使用timedelta这个类 转 ...

  10. python常用内建模块--datetime

    datetime模块中的datetime类: 获取当前时间:datetime.now() 当前操作系统时区时间,date.utctime(UTC时间) 转换成时间戳:timestamp() 和具体时区 ...

随机推荐

  1. WAF防火墙学习

    正则解析神器 http://rick.measham.id.au/paste/explain.pl http://regexr.com/ http://regex101.com/ http://www ...

  2. 黑客已经瞄准5G网络,如何防止LTE网络攻击?

    黑客是如何攻击5G网络?即使5G进行大规模应用,LTE技术会被淘汰吗?那么我们应该如何防止LTE网络攻击? 5G-网络黑客 即将推出的5G网络也可能容易受到这些攻击,来自中国网络安全研究人员表示,尽管 ...

  3. springboot2.0整合redis的发布和订阅

    1.Maven引用 <dependency> <groupId>org.springframework.boot</groupId> <artifactId& ...

  4. django 使用ORM插入数据,提示Cannot assign "1": "B" must be a "Projectconfig" instance.

    这是因为使用了外键导致的, 如果使用了外键,先实例化外键查询,然后再插入的表里面放入实例化后的外键连接

  5. redis下载及安装教程

    https://blog.csdn.net/w546097639/article/details/88547486

  6. shell学习----正则表达式

    在使用sed和gawk时如果能够熟练的使用正则表达式,可以准确的过滤到自己需要的信息 Linux中,有两种流行的正则表达式引擎: POSIX基础正则表达式,BRE引擎 POSIX扩展正则表达式,ERE ...

  7. js点击获取—通过JS获取图片的相对坐标位置

    一.通过JS获取鼠标点击时图片的相对坐标位置 源代码如下所示: <!DOCTYPE html> <html lang="en"> <head> ...

  8. nginx proxy大文件上传失败问题总结

    问题描述: http://www.syhuo.net ota.apk包上传正常 http://www.syhuo.net:8080 ota.apk包上传不正常 查看nginx error日志 [roo ...

  9. 4.HTML 常用标签及属性

    1. 链接 标签: <a></a> 属性: href:链接地址 target:打开方式 _blank:新标签页打开 _self:当前页面打开(默认) title:链接提示 2. ...

  10. mypwd实现

    实现mypwd 要求 1 学习pwd命令 2 研究pwd实现需要的系统调用(man -k; grep),写出伪代码 3 实现mypwd 4 测试mypwd 步骤 查看pwd的作用man -k pwd ...