【编程】Python3 正则表达式使用笔记
前言
Python 从1.5版本开始使用re模块来处理正则表达式。
我们可以使用“re模块”或“re.compile方法”来创建正则表达式对象(re.RegexObject),然后通过调用相应方法来处理字符数据。(关于正则表达式语法的相关内容,可以参考这篇文章,本文不再赘述)
1 # 使用re模块直接调用相应方法处理正则表达式
2 re.match()
3
4 # 使用compile方法创建正则表达式对象,调用相应方法处理正则表达式
5 RegexObject = re.compile()
6 RegexObject.match()
7
8 #当正则表达式成功匹配后,会返回一个MatchObject对象,可以通过调用以下方法获取匹配结果
9 group() 获得一个或多个分组匹配的字符串
10 groups() 从第1个分组开始,将匹配到的所有字符串以元组的形式返回
11 start() 获取分组匹配的子串在整个字符串中的起始位置(子串第一个字符的索引)
12 end() 获取分组匹配的子串在整个字符串中的结束位置
13 span() 返回 (start(group), end(group))
功能函数
re.compile(pattern, flags)
用于编译正则表达式,生成一个正则表达式对象。

1 #参数:
2 pattern: 一个字符串形式的正则表达式
3 flags: 可选,表示匹配模式,比如忽略大小写,多行模式等
4
5 #示例
6 obj = re.compile("123")
7 strr = obj.match("123a456").group()
8 print(strr) #123
re.match(pattern, string, flags=0)
从字符串的起始位置开始匹配,如果不是起始位置匹配成功的话,返回none。

1 #参数
2 pattern: 正则表达式
3 string: 要匹配的字符串
4 flags: 可选,表示匹配模式,比如忽略大小写,多行模式等
5
6 #示例
7 strr = re.match("123", "123a456").group()
8 print(strr) #123 (只能从字符串头部开始匹配,否则返回none)
re.search(pattern, string, flags=0)
从整个字符串开始匹配,返回第一个成功匹配的结果。

1 #参数
2 pattern: 正则表达式
3 string: 要匹配的字符串
4 flags: 可选,表示匹配模式,比如忽略大小写,多行模式等
5
6 #示例
7 strr = re.search("abc", "123abc456abc").group()
8 print(strr) #abc (有多个符合时,只返回第一个匹配的结果)
re.findall(pattern, string, flags=0)
从整个字符串开始匹配,将成功匹配的所有子串用列表返回,如果匹配失败返回空列表。

1 #参数
2 pattern: 正则表达式
3 string: 要匹配的字符串
4 pos: 可选参数,指定字符串的起始位置,默认为0
5 endpos: 可选参数,指定字符串的结束位置,默认为字符串长度
6
7 #示例
8 strr = re.findall("abc", "123abc456abc")
9 print(strr) #['abc', 'abc'] (有多个符合时,返回所有匹配的结果)
10
11 obj = re.compile("abc")
12 strr = obj.findall("123abc456abc", 0, 8)
13 print(str2) #['abc'] (指定起始位置和结束位置后,只有第一个abc能成功匹配)
re.finditer(pattern, string, flags=0)
从整个字符串开始匹配,将成功匹配的所有子串用一个迭代器返回,如果匹配失败返回空迭代器。

1 #参数
2 pattern: 正则表达式
3 string: 要匹配的字符串
4 flags: 可选,表示匹配模式,比如忽略大小写,多行模式等
5
6 #示例
7 it = re.finditer("abc", "123abc456abc")
8 for strr in it:
9 print(strr.group()) #abc abc
re.sub(pattern, repl, string, count=0, flags=0)
从整个字符串开始匹配,并使用指定字符串替换成功匹配的结果。

1 #参数
2 pattern: 正则表达式
3 repl: 用于替换的字符串(也可以是一个函数)
4 string: 用于查找后被替换的原始字符串
5 count: 可选,成功匹配后要替换的次数,默认0表示替换所有的匹配结果
6 flags: 可选,表示匹配模式,比如忽略大小写,多行模式等
7
8 #示例
9 strr = re.sub("abc", "", "123abc456abc")
10 print(strr) #123456
re.split(pattern, string, maxsplit=0, flags=0)
从整个字符串开始匹配,用成功匹配的子串对整个字符串进行分割,分割结果用列表返回。

1 #参数
2 pattern: 正则表达式
3 string: 要匹配的字符串
4 maxsplit: 可选,分隔次数,maxsplit=1 分隔一次,默认为0,不限制次数
5 flags: 可选,表示匹配模式,比如忽略大小写,多行模式等
6
7 #示例
8 strr1 = re.split("abc", "123abc456abc")
9 strr2 = re.split("abc", "123abc456abc", 1)
10 print(strr1) #['123', '456', '']
11 print(strr2) #['123', '456abc']
参考链接
https://www.runoob.com/python3/python3-reg-expressions.html
【编程】Python3 正则表达式使用笔记的更多相关文章
- python3 正则表达式学习笔记
re.match函数 re.match 尝试从字符串的起始位置匹配一个模式,如果不是起始位置匹配成功的话,match()就返回none. ~匹配成功re.match方法返回一个匹配的对象,否则返回No ...
- Python3正则表达式学习笔记
学习前准备:导入re模块 import re 一.re的核心函数 1 - re.compile(pattern[, flags]) 编译正则表达式,速度快 2 - re.match(pattern, ...
- python3.4学习笔记(十二) python正则表达式的使用,使用pyspider匹配输出带.html结尾的URL
python3.4学习笔记(十二) python正则表达式的使用,使用pyspider匹配输出带.html结尾的URL实战例子:使用pyspider匹配输出带.html结尾的URL:@config(a ...
- python3.4学习笔记(五) IDLE显示行号问题,插件安装和其他开发工具介绍
python3.4学习笔记(五) IDLE显示行号问题,插件安装和其他开发工具介绍 IDLE默认不能显示行号,使用ALT+G 跳到对应行号,在右下角有显示光标所在行.列.pycharm免费社区版.Su ...
- python3.4学习笔记(十七) 网络爬虫使用Beautifulsoup4抓取内容
python3.4学习笔记(十七) 网络爬虫使用Beautifulsoup4抓取内容 Beautiful Soup 是用Python写的一个HTML/XML的解析器,它可以很好的处理不规范标记并生成剖 ...
- python3.4学习笔记(十三) 网络爬虫实例代码,使用pyspider抓取多牛投资吧里面的文章信息,抓取政府网新闻内容
python3.4学习笔记(十三) 网络爬虫实例代码,使用pyspider抓取多牛投资吧里面的文章信息PySpider:一个国人编写的强大的网络爬虫系统并带有强大的WebUI,采用Python语言编写 ...
- 《Java编程思想》读书笔记(二)
三年之前就买了<Java编程思想>这本书,但是到现在为止都还没有好好看过这本书,这次希望能够坚持通读完整本书并整理好自己的读书笔记,上一篇文章是记录的第一章到第十章的内容,这一次记录的是第 ...
- python3.4学习笔记(十四) 网络爬虫实例代码,抓取新浪爱彩双色球开奖数据实例
python3.4学习笔记(十四) 网络爬虫实例代码,抓取新浪爱彩双色球开奖数据实例 新浪爱彩双色球开奖数据URL:http://zst.aicai.com/ssq/openInfo/ 最终输出结果格 ...
- 《Linux/Unix系统编程手册》读书笔记 目录
<Linux/Unix系统编程手册>读书笔记1 (创建于4月3日,最后更新4月7日) <Linux/Unix系统编程手册>读书笔记2 (创建于4月9日,最后更新4月10日) ...
- 《Linux/Unix系统编程手册》读书笔记9(文件属性)
<Linux/Unix系统编程手册>读书笔记 目录 在Linux里,万物皆文件.所以文件系统在Linux系统占有重要的地位.本文主要介绍的是文件的属性,只是稍微提及一下文件系统,日后如果有 ...
随机推荐
- 【当年笔记】Collection集合部分
集合继承关系图 1)Vector 特点:线程安全,消耗偏大 2)ArrayList 特点:基于数组实现,随机访问某个元素效率高.集和头尾之间包括头插入删除操作效率较低,因为插入元素后,其他元素要后移. ...
- GeoServer 发布PostGIS数据库中的栅格数据
1.导入栅格数据 进入PostgreSQL\bin目录,利用raster2pgsql工具导入栅格数据,具体命令如下所示: <!-- 分块,切片存储到PostGIS数据库中 --> rast ...
- SpringBoot_Thymeleaf项目开发
用Springboot集成Thymeleaf,开发一个前后端不分离的Web项目,记录下每个步骤:(IDEA版) 一.项目初始化: 1.打开idea,以次点击 File -- New -- Projec ...
- easyui subGrid实现
$(function(){ $('#dg').datagrid({ view: detailview, detailFormatter:function(index,row){ return '< ...
- drush use dev.mentor.com | expecting statement
在多站点的环境中, 不清楚在哪个目录下运行drush cc all, 这时可以运行 drush use dev.mentor.com然后还发现一个很搞笑的事情, 在一个文件的末尾一直现实红色报错符号, ...
- 記錄一下oracle数据库系统的comment數據字典(轉載)
一.comment是oracle数据库系统的关键字,所以不能用来命名表明或字段名 二.comment关键字用于对表,字段添加注释,有利于用户对表结构以及数据库对象含义的理解. 三.用户可以通过数据字典 ...
- 记一个在线工具网站,程序员必备,json格式化、压缩、转义,加解密 编码解码
简用-在线工具箱-简单易用-工具大全 提供 json格式化,json代码压缩,json校验解析,json数组解析,json转xml,xml转json,json解析,json在线解析,json在线解析及 ...
- gitee 上传远程仓库失败
1:添加本地id_rsa.pub文件内容到gitee SSH Keys (添加公开密钥) 2:设置本地的邮箱和用户名 git config --global user.name "MARS& ...
- npm 使用阿里源
npm config set registry https://registry.npm.taobao.org/ npm config get registry 安装vue-cli 报错 npm in ...
- mysql数据增量及备份操作
注:当数据库出现异常的时候,我们可以先恢复最近一次的全量备份,接着将增量备份的文件一个一个按顺序恢复即可实现原来数据库的恢复. 还可以使用innobackupex 备份工具. 备份 # 1,开启 bi ...