Python之正则表达式笔记
概述
概念
Regular Expression
一种文本模式,描述在搜索文本时要匹配的一个或多个字符串
典型场景
数据验证、文本扫描、文本提取、文本替换、文本分割
语法
字面值
普通字符
需转义:\ ^ $ . | ? * + () [] {}
元字符
匹配
单字,预定义元字符
. 除\n外的所有字符 \d 数字,等同于[0-9] \D非数字,等同于[^0-9]
\s 空白字符 \t\n\r\f\v \S 非空白字符[^\t\n\r\f\v]
\w 字母数字字符[a-zA-Z0-9_] \W 非字线数字[^a-zA-Z0-9_]
批量备选 | yes|no
量词(字符、元字符,字符集如何重复)
? 0或1次 * 0或多次 + 1或多次
特定: {n,m}范围次数 {n}n次 {n,}至少n次 {,m}最多m次
贪婪与非贪婪
贪婪(默认):尽量匹配最大范围结果
非贪婪
尽量匹配最小的范围结果
方法:量词后追加? 例:?? *? +?
边界匹配
^ 行首 $ 行尾 \b 单词边界 \B 非单词边界 \A 输入开头 \Z 输入结尾
注:或因上下文差异有不同表
Python 正则
模块 import re
RegexObject 正则对象
模式对象,表现编译后的正则表达式(编译为字节码并缓存)
编译 re.compile('模式')
.findall() 1查找所有非重叠匹配项 2返回list
.match(string[,pos[,endpos]]) 1匹配,仅从开始位置 2返回MatchObject
.search(string[,[pos[,endpos]]) 1任意位置搜索 2返回MatchObject
.finditer() 1查找所有匹配项 2返回包括MatchObject元素的迭代器
MatchObject 匹配对象
表现被匹配的模式
.group() 1参数为0或空返回整个匹配 2有参时返回特定分组匹配细节 3参数也可以是分组名称
.groups() 返回包含所有子分组的元组
.start() 返回特定分组的起始索引
.end() 返回特定分组的终止索引
.groupdict() 以字典表形式返回分组名及结果
Group 编组
场景 1从匹配模式中提取信息 2创建子正则以应用量词 3限制备选项范围
4重用正则模式中提取的内容
声明 1(模式) 2(?P<name>模式)
引用 1匹配对象内 m.group('name') 2模式内 (?P=name) 3表现内 \g<name>
应用
字符串操作 1 .split(string, maxsplit=0) 分割字符串
2 .sub(repl, string, count=0) 替换字符串
3 .subn(repl, string, count=0) 替换并返回替换数量
编译标记 1 改变正则的默认行为 2 re.I 忽略大小写 3 re.M 匹配多行
4 re.S 指定"."匹配所有字符,包括\n …
模块级别操作 1 re.purge() 清理正则缓存 2 re.escape() 逃逸字符
Python之正则表达式笔记的更多相关文章
- Python的正则表达式笔记
		
1. "先抓大再抓小": 遇到一个正则表达式无法一次性筛选出所需内容时, 可以先在一个范围内筛选第一次, 再在小范围中筛选第二次. 2. pattern = re.compile( ...
 - (转)Python爬虫学习笔记(2):Python正则表达式指南
		
以下内容转自CNBLOG:http://www.cnblogs.com/huxi/archive/2010/07/04/1771073.html 1. 正则表达式基础 1.1. 简单介绍 正则表达式并 ...
 - 《简明python教程》笔记一
		
读<简明Python教程>笔记: 本书的官方网站是www.byteofpython.info 安装就不说了,网上很多,这里就记录下我在安装时的问题,首先到python官网下载,选好安装路 ...
 - python核心编程--笔记
		
python核心编程--笔记 的解释器options: 1.1 –d 提供调试输出 1.2 –O 生成优化的字节码(生成.pyo文件) 1.3 –S 不导入site模块以在启动时查找pyt ...
 - Python网络爬虫笔记(五):下载、分析京东P20销售数据
		
(一) 分析网页 下载下面这个链接的销售数据 https://item.jd.com/6733026.html#comment 1. 翻页的时候,谷歌F12的Network页签可以看到下面 ...
 - Python:正则表达式详解
		
正则表达式是一个很强大的字符串处理工具,几乎任何关于字符串的操作都可以使用正则表达式来完成,作为一个爬虫工作者,每天和字符串打交道,正则表达式更是不可或缺的技能,正则表达式的在不同的语言中使用方式可能 ...
 - Python标准库笔记(8) — pprint模块
		
struct模块提供了用于在字节字符串和Python原生数据类型之间转换函数,比如数字和字符串. Python版本: 2.x & 3.x 该模块作用是完成Python数值和C语言结构体的Pyt ...
 - python基础===正则表达式(转)
		
正则表达式是一个很强大的字符串处理工具,几乎任何关于字符串的操作都可以使用正则表达式来完成,作为一个爬虫工作者,每天和字符串打交道,正则表达式更是不可或缺的技能,正则表达式的在不同的语言中使用方式可能 ...
 - Python的正则表达式re模块
		
Python的正则表达式(re模块) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. Python使用re模块提供了正则表达式处理的能力.如果对正则表达式忘记的一干二净的话,可以花费 ...
 
随机推荐
- kvm 学习(二)镜像
			
Linux下 如何通过命令行使用现有的镜像创建.启动kvm虚拟机 这里假定已经创建好了相应的镜像: eg:我这里制作的镜像名称为zu1-centos7.img # ls zu1-centos7.img ...
 - ICEM-带肋圆柱
			
原视频下载地址:https://yunpan.cn/cqUj6H9un37F2 访问密码 91af
 - 【Python代码】随机抽取文件名列表NameList中的Name作为训练集
			
#!/usr/bin/env python #coding=utf-8 #随机抽取一部分图片作为测试集 import random NameList=[]#存储所有图片名字 ''' NameListP ...
 - 关于大JSON 的问题的解决方式
			
ASP.NET MVC JSON 大数据异常提示JSON 字符串超出限制的异常问题 今天客户突然过来找我说在后台添加了一篇超长的文章后,所有后台的文章都显示不出来了.后台的前端显示是用easyui的, ...
 - this.getClass()和super.getClass()得到的是同一个类
			
今天dubug代码时发现this.getClass()和super.getClass()得到的竟然是同一个类,都是当前类. 遍访网络资料得出: getClass()不受this和super影响,而是有 ...
 - keras检查点的保存
			
来自 keras的文档:https://keras.io/callbacks/#callback ModelCheckpoint keras.callbacks.ModelCheckpoint(fil ...
 - 复制粘贴引发的鸠占鹊巢——IDEA复制项目导致sources root复用了另一个项目
			
复制粘贴大法一向是程序猿的利器,但有时也会引发一些拎不清的麻烦关系来.比如我们现在想新建一个项目,为了快速而对原来的uis-gateway动用了复制粘贴大法,然后改改项目名就成了uis-applica ...
 - Linux 7 关闭、禁用防火墙服务
			
1 查看防火墙状态 [root@lvxinghao ~]# systemctl status firewalld 2 查看开机是否启动防火墙服务 [root@lvxinghao ~]# systemc ...
 - iOS 字符串和图片互转
			
for (UIImage *myImg in _imgArray) { NSData *imageData = UIImageJPEGRepresentation(myImg,0.5); NSStri ...
 - python检测文件的MD值
			
使用hashlib模块,可对文件MD5一致性加密验证: #python 检测文件MD5值 #python version 2.6 import hashlib import os,sys #简单的测试 ...