python常用模块----re模块
正则表达式就是匹配字符串内容的一种规则。
字符组:
[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 : 返回所有满足匹配条件的结果,放在列表里
import re
ret = re.findall('e','nice to meet you')
print(ret) # ['e', 'e', 'e']
search : 函数会在字符串内查找模式匹配,只到找到第一个匹配然后返回一个包含匹配信息的对象,该对象可以 通过调用group()方法得到匹配的字符串,如果字符串没有匹配,则返回None。
import re
ret = re.search('e','nice to meet you')
print(ret.group()) # e
ret = re.search('a','nice to meet you')
print(ret) # None
match : 同search,不过仅仅只是在字符串开始处进行匹配
import re
ret = re.match('n','nice to meet you')
print(ret.group()) # n
ret = re.match('t','nice to meet you')
print(ret) # None
split :分割
ret = re.split('[ab]','abcd')
print(ret) # ['', '', 'cd'] 先按'a'分割得到''和'bcd',在对''和'bcd'分别按'b'分割
ret = re.split('ab','abcd')
print(ret) # ['', 'cd'] 按ab整体进行切割,左边'',右边'cd' ret = re.split('b','abcd')
print(ret) # ['a', 'cd'] ret = re.split('[bc]','abcd')
print(ret) # ['a', '', 'd']
ret = re.split('[d]','abcd')
print(ret) # ['abc', '']
split
sub : 替换
ret = re.sub('\d','L','gh2cj4df89ab')
print(ret) # ghLcjLdfLLab 将数字替换成'L' ,最后那个参数不写,则默认全部替换
ret = re.sub('\d','L','gh2cj4df89ab',1)
print(ret) # ghLcj4df89ab 最后那个参数是1表示只替换1个,从左边开始找
ret = re.sub('h','L','gh2cjh4df89ab')
print(ret) # gL2cjL4df89ab
sub
subn : 替换,返回元组
ret = re.subn('\d','L','gh2cj4df89ab')
print(ret) # ('ghLcjLdfLLab', 4) 将数字替换成'L' ,返回元组 (替换后的字符串,替换了多少次) 最后那个参数不写,则默认全部替换
ret = re.subn('\d','L','gh2cj4df89ab',3)
print(ret) # ('ghLcjLdfL9ab', 3) 只替换了3次
subn
compile : 编译
import re
obj = re.compile('\d{3}') #将正则表达式编译成为一个 正则表达式对象,规则要匹配的是3个数字
re = obj.findall('ab125djj5671sjjk') #正则表达式对象调用findall,参数为待匹配的字符串
print(re) # ['125', '567']
finditer : 返回一个存放匹配结果的迭代器
import re
ret = re.finditer('\d','hgd2dff6s4av1')
print(ret) # <callable_iterator object at 0x000001FC67470160>
print(next(ret).group()) # 2 查看第一个结果
print(ret.__next__().group()) # 6 查看第二个结果
print([i.group() for i in ret]) # ['4', '1'] 查看剩余的结果
finditer
findall的优先级查询:
import re
ret = re.findall('www.(baidu|cnblogs).com','www.cnblogs.com')
print(ret) # ['cnblogs'] 这是因为findall会优先把匹配结果组里内容返回,如果想要匹配结果,取消权限即可
ret = re.findall('www.(?:baidu|cnblogs).com','www.cnblogs.com')
print(ret) # ['www.cnblogs.com']
split的优先级查询:
import re
ret = re.split('\d+','lucy2lilei3jim4lily')
print(ret) # ['lucy', 'lilei', 'jim', 'lily']
ret = re.split('(\d+)','lucy2lilei3jim4lily')
print(ret) # ['lucy', '2', 'lilei', '3', 'jim', '4', 'lily']
#在匹配部分加上()之后所切出的结果是不同的,
#没有()的没有保留所匹配的项,但是有()的却能够保留了匹配的项,
#这个在某些需要保留匹配部分的使用过程是非常重要的。
python常用模块----re模块的更多相关文章
- Python常用内建模块
Python常用内建模块 datetime 处理日期和时间的标准库. 注意到datetime是模块,datetime模块还包含一个datetime类,通过from datetime import da ...
- python常用内建模块 collections,bs64,struct,hashlib,itertools,contextlib,xml
# 2 collections 是Python内建的一个集合模块,提供了许多有用的集合类. # 2.1 namedtuple #tuple可以表示不变集合,例如,一个点的二维坐标就可以表示成: p ...
- Python 常用内建模块(time ,datetime)
1,在Python中,与时间处理有关的模块就包括:time,datetime以及calendar. 2,在Python中,通常有这几种方式来表示时间:1)时间戳 2)格式化的时间字符串 3)元组(st ...
- python常用命令—查看模块所在位置
环境:ipython3 交互式解释器 语法: import 模块名 模块名.__file__ 功能: 查看模块的所在位置 例:
- python常用函数及模块
原文来源于博客园和CSDN 1.计算函数 abs()--取绝对值 max()--取序列最大值,包括列表.元组 min()--取序列最小值 len()--取长度 divmod(a,b)---取a//b除 ...
- Python 常用内建模块(os, sys,random)
一.os 模块 1,操作系统与环境变量 import osprint(os.name) #操作系统类型,如果是posix 说明系统是linux unix 或 mac os x :如果是nt 就是win ...
- python常用内建模块——datetime
datetime是python处理日期和时间的标准库. 获取当前日期和时间 >>>from datetime import datetime >>>now = da ...
- collections(python常用内建模块)
文章来源:https://www.liaoxuefeng.com/wiki/897692888725344/973805065315456 collections collections是Python ...
- Python常用内建模块和第三方库
目录 内建模块 1 datetime模块(处理日期和时间的标准库) datetime与timestamp转换 str与datetime转换 datetime时间加减,使用timedelta这个类 转 ...
- python常用内建模块--datetime
datetime模块中的datetime类: 获取当前时间:datetime.now() 当前操作系统时区时间,date.utctime(UTC时间) 转换成时间戳:timestamp() 和具体时区 ...
随机推荐
- ReentrantReadWriteLock实现原理
在java并发包java.util.concurrent中,除了重入锁ReentrantLock外,读写锁ReentrantReadWriteLock也很常用.在实际开发场景中,在使用共享资源时,可能 ...
- Maven 集成Tomcat插件(引用)
Maven已经是Java的项目管理标配,如何在JavaEE开发使用Maven调用Web应用,是很多同学关心的问题.本文将介绍,Maven如何介绍Tomcat插件. Maven Tomcat插件现在主要 ...
- VirtualBox中安装CentOS 7
1.如下所示图,点击“新建”,创建一个新的虚拟机 2.类型选择Linux,版本选择Red Hat,下一步 3.分配内存大小,电脑8G内存,所以分给虚拟机2G,选择下一步 4.选择“现在创建虚拟硬盘” ...
- 求助:关于shell数值比较的错误提示
今天写了个脚本,过不了错误这一关,求大神路过瞟一眼. 1 #!/bin/bash 2 #disk use 3 disk_use() { 4 DISK_LOG=/tmp/disk_use.tmp 5 D ...
- Mysql查询结果导出Excel表
Mysql查询结果导出Excel表: 一句转换方式:$ mysql -uops -p'GCNgH000KP' dtbs -e 'select * from t_proxy__record;' --de ...
- PyCharm使用技巧总结
PyCharm高频使用快捷键 快速修复:ALT + ENTER 搜索: 双击Shif 垂直分隔窗口: ALT + V 另起一行: SHIFT + ENTER 删除当前插入符所在的行: Ctrl + Y ...
- 2、Jmeter测试
一.测试流程 1.添加本次测试计划 (右键-->添加-->Threads(Users)-->线程组) 2.设置线程数 (所谓线程数就是并发用户数) 3.在线程组内添加请求(右键--& ...
- node.js从入门到放弃《模块》
在计算机程序的开发过程中,随着程序代码越写越多,在一个文件里代码就会越来越长,越来越不容易维护. 为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文件包含的代码就相对较少,很 ...
- java并发学习--第四章 JDK提供的线程原子性操作工具类
在了解JDK提供的线程原子性操作工具类之前,我们应该先知道什么是原子性:在多线程并发的条件下,对于变量的操作是线程安全的,不会受到其他线程的干扰.接下来我们就学习JDK中线程的原子性操作. 一.CAS ...
- dede标签大全
想必很多人对后台不熟悉,并且觉得很难.其实不难,只是你们没有找到合适的方法学习而已!只有找到一个合适的学习方法,不管做什么事情,我想都很容易.学习讲究的是效率,而效率又是由思路决定的.就拿网页制作来说 ...