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模块提供了正则表达式处理的能力.如果对正则表达式忘记的一干二净的话,可以花费 ...
随机推荐
- mysql使用慢查询日志分析数据执行情况
#查询慢查询日志文件路径show variables like '%slow_query%';#开启慢查询日志 ; #设置慢查询阀值为0,将所有的语句都记入慢查询日志 ;#未使用索引的查询也被记录到慢 ...
- kill 一个名字 程序的所有进程
ps aux | grep chrome | awk '{print $2}' | xargs kill -9
- Matlab注释的几个方法
Matlab最简单的注释当然是 %x= %这是注释,无法运行 x= %结果为2 然而%只能注释一行,如何注释更加快捷简便地注释多行呢? %{ .这就是传说中的多行注释 .成功! %} 经常需要调试程序 ...
- 治理Go模块 服务治理 中台业务 Golang的net.Conn接口,double close
小结: 1.中台业务 前台业务 快车.专车.顺风车,在滴滴这些业务线叫做前台服务,他们有一些共同的特性,都有司机信息,订单的状态,收银,账号等等这些业务逻辑,我们会把专门的业务逻辑集合起来,形成专职的 ...
- ios 新建app iphone 、 ipad or universal ?
很久没有关注这个新建app的 时候 选什么的问题了, 因为我们一般在公司 都是 已经建立好的app 直接 在那上面开发. 所以很久不建立新app 遇到新的app需要你自己去创建的时候 可能就会 有突 ...
- ISO/IEC 9899:2011 条款6.2.8——对象的对齐
6.2.8 对象的对齐 1.完整的对象类型具有对齐要求,对齐要求是对该类型对象可以在哪个地址进行分配的放置限制.一个对齐是一个实现定义的整数值,表示一个给定对象可以分配在相继两个地址之间跨多少字节的位 ...
- Rabbitmq Plugin configuration unchanged. 问题完全解决方案
当执行:rabbitmq-plugins.bat enable rabbitmq_management 命令时候出现 错误如下: Plugin configuration unchanged. App ...
- IDEA 不编译java以外的文件
解决办法:修改pom 文件 <build> <resources> <resource> <directory>src/main/java</di ...
- osg::NodeVisitor osg3.4.0
x:-89.4588 y:-12.1245 z:-11.7807x:-89.4588 y:-6.44823 z:-11.7807x:-89.2164 y:-9.07239 z:-11.811x:-89 ...
- spark "main" java.lang.ArrayIndexOutOfBoundsException: 10582
升级 你的 paranamer 到2.8 ,这是由于你的jdk版本1.8导致 <!-- https://mvnrepository.com/artifact/com.thoughtworks.p ...