欢迎来到个人简历网!永久域名:gerenjianli.cn (个人简历全拼+cn)
当前位置:首页 > 范文大全 > 实用文>Python正则表达式的七个使用详解

Python正则表达式的七个使用详解

2023-07-01 08:17:32 收藏本文 下载本文

“yingyingi”通过精心收集,向本站投稿了7篇Python正则表达式的七个使用详解,下面小编给大家带来Python正则表达式的七个使用详解,希望能帮助到大家!

Python正则表达式的七个使用详解

篇1:Python正则表达式的七个使用详解

本文是一系列关于Python正则表达式文章的其中一部分,在这个系列的第一篇文章中,我们将重点讨论如何使用Python中的正则表达式并突出Python中一些独有的特性

作为一个概念而言,正则表达式对于Python来说并不是独有的。但是,Python中的正则表达式在实际使用过程中还是有一些细小的差别。

本文是一系列关于Python正则表达式文章的其中一部分。在这个系列的第一篇文章中,我们将重点讨论如何使用Python中的正则表达式并突出Python中一些独有的特性。

我们将介绍Python中对字符串进行搜索和查找的一些方法。然后我们讲讨论如何使用分组来处理我们查找到的匹配对象的子项。

我们有兴趣使用的Python中正则表达式的模块通常叫做‘re‘。

>>>import re

1. Python中的原始类型字符串

Python编译器用‘\‘(反斜杠)来表示字符串常量中的转义字符。

如果反斜杠后面跟着一串编译器能够识别的特殊字符,那么整个转义序列将被替换成对应的特殊字符(例如,‘\n‘将被编译器替换成换行符)。

但这给在Python中使用正则表达式带来了一个问题,因为在‘re‘模块中也使用反斜杠来转义正则表达式中的特殊字符(比如*和+)。

这两种方式的混合意味着有时候你不得不转义转义字符本身(当特殊字符能同时被Python和正则表达式的编译器识别的时候),但在其他时候你不必这么做(如果特殊字符只能被Python编译器识别)。

与其将我们的心思放在去弄懂到底需要多少个反斜杠,我们可以使用原始字符串来替代。

原始类型字符串可以简单的通过在普通字符串的双引号前面加一个字符‘r‘来创建。当一个字符串是原始类型时,Python编译器不会对其尝试做任何的替换。本质上来讲,你在告诉编译器完全不要去干涉你的字符串。

>>>string = ‘This is a\nnormal string‘>>>rawString = r‘and this is a\nraw string‘>>>print string 这是一个普通字符串 >>>print rawString and this is a\nraw string 这是一个原始类型字符串。

在Python中使用正则表达式进行查找

‘re‘模块提供了几个方法对输入的字符串进行确切的查询。我们将会要讨论的方法有:

•re.match

•re.search()

•re.findall()

每一个方法都接收一个正则表达式和一个待查找匹配的字符串。让我们更详细的查看这每一个方法从而弄明白他们是如何工作的以及他们各有什么不同。

2. 使用re.match查找 C 匹配开始

让我们先来看一下match()方法。match()方法的工作方式是只有当被搜索字符串的开头匹配模式的时候它才能查找到匹配对象。

举个例子,对字符串‘dog cat dog‘调用mathch()方法,查找模式‘dog‘将会匹配:

>>>re.match(r‘dog‘, ‘dog cat dog‘) <_sre.SRE_Match object at 0xb743e720< >>>match = re.match(r‘dog‘, ‘dog cat dog‘) >>>match.group(0) ‘dog‘

我们稍后将更多的讨论group()方法。现在,我们只需要知道我们用0作为它的参数调用了它,group()方法返回查找到的匹配的模式。

我还暂且略过了返回的SRE_Match对象,我们很快也将会讨论到它。

但是,如果我们对同一个字符串调用math()方法,查找模式‘cat‘,则不会找到匹配。

>>>re.match(r‘cat‘, ‘dog cat dog‘) >>>

3. 使用re.search查找 C 匹配任意位置

search()方法和match()类似,不过search()方法不会限制我们只从字符串的开头查找匹配,因此在我们的示例字符串中查找‘cat‘会查找到一个匹配:

search(r‘cat‘, ‘dog cat dog‘) >>>match.group(0) ‘cat‘

然而search()方法会在它查找到一个匹配项之后停止继续查找,因此在我们的示例字符串中用searc()方法查找‘dog‘只找到其首次出现的位置。

>>>match = re.search(r‘dog‘, ‘dog cat dog‘) >>>match.group(0) ‘dog‘

4. 使用 re.findall C 所有匹配对象

目前为止在Python中我使用的最多的查找方法是findall()方法。当我们调用findall()方法,我们可以非常简单的得到一个所有匹配模式的列表,而不是得到match的对象(我们会在接下来更多的讨论match对象)。对我而言这更加简单。对示例字符串调用findall()方法我们得到:

[‘dog‘, ‘dog‘] >>>re.findall(r‘cat‘, ‘dog cat dog‘) [‘cat‘]

5. 使用 match.start 和 match.end 方法

那么,先前search()和match()方法先前返回给我们的‘match‘对象”到底是什么呢?

和只简单的返回字符串的匹配部分不同,search()和match()返回的“匹配对象”,实际上是一个关于匹配子串的包装类,

先前你看到我可以通过调用group()方法得到匹配的子串,(我们将在下一个部分看到,事实上匹配对象在处理分组问题时非常有用),但是匹配对象还包含了更多关于匹配子串的信息。

例如,match对象可以告诉我们匹配的内容在原始字符串中的开始和结束位置:

>>>match = re.search(r‘dog‘, ‘dog cat dog‘) >>>match.start() 0>>>match.end() 3

知道这些信息有时候非常有用。

6. 使用 mathch.group 通过数字分组

就像我之前提到的,匹配对象在处理分组时非常得心应手。

分组是对整个正则表达式的特定子串进行定位的能力。我们可以定义一个分组做为整个正则表达式的一部分,然后单独的对这部分对应匹配到的内容定位。

让我们来看一下它是怎么工作的:

>>>contactInfo = ‘Doe, John: 555-1212‘

我刚才创建的字符串类似一个从某人的地址本里取出来的一个片段。我们可以通过这样一个正则表达式来匹配这一行:

>>>re.search(r‘\w+, \w+: \S+‘, contactInfo) <_sre.SRE_Match object at 0xb74e1ad8<

通过用圆括号来(字符‘(‘和‘)‘)包围正则表达式的特定部分,我们可以对内容进行分组然后对这些子组做单独处理。

>>>match = re.search(r‘(\w+), (\w+): (\S+)‘, contactInfo)

这些分组可以通过用分组对象的group()方法得到。它们可以通过其在正则表达式中从左到右出现的数字顺序来定位(从1开始):

>>>match.group(1) ‘Doe‘>>>match.group(2) ‘John‘>>>match.group(3) ‘555-1212‘

组的序数从1开始的原因是因为第0个组被预留来存放所有匹配对象(我们在之前学习match()方法和search()方法到时候看到过)。

>>>match.group(0) ‘Doe, John: 555-1212‘

7. 使用 match.group 通过别名来分组

有时候,特别是当一个正则表达式有很多分组的时候,通过组的出现次序来定位就会变的不现实。Python还允许你通过下面的语句来指定一个组名:

>>>match = re.search(r‘(?P\w+), (?P\w+): (?P

\S+)‘, contactInfo)

我们还是可以用group()方法获取分组的内容,但这时候我们要用我们所指定的组名而不是之前所使用的组的所在位数。

>>>match.group(‘last‘) ‘Doe‘>>>match.group(‘first‘) ‘John‘>>>match.group(‘phone‘) ‘555-1212‘

这大大加强了代码的明确性和可读性。你可以想像当正则表达式变得越来越复杂,去弄懂一个分组到捕获了什么内容将会变得越来越困难。给你的分组命名将明确的告诉了你和你的读者你的意图。

尽管findall()方法不返回分组对象,它也可以使用分组。类似的,findall()方法将返回一个元组的集合,其中每个元组中的第N个元素对应了正则表达式中的第N个分组。

>>>re.findall(r‘(\w+), (\w+): (\S+)‘, contactInfo) [(‘Doe‘, ‘John‘, ‘555-1212‘)]

但是,给分组命名并不适用于findall()方法。

在本文中我们介绍了Python中使用正则表达式的一些基础。我们学习了原始字符串类型(还有它能帮你解决的在使用正则表达式中一些头痛的问题)。我们还学习了如何适使用match(), search(), and findall()方法进行基本的查询,以及如何使用分组来处理匹配对象的子组件。

和往常一样,如果想查看更多关于这个主题的内容,re模块的Python官方文档是一个非常好的资源。

在以后的文章中,我们将更深入的讨论Python中正则表达式的应用。我们将更加全面的学习匹配对象,学习如何使用它们在字符串中做替换,甚至使用它们从文本文件中去解析Python数据结构。

本文由 伯乐在线 - 左手的灵魂 翻译自 thegeekstuff。

篇2:python正则表达式re模块详解

最近更 新

python实现代理服务功能实例

python网络编程学习笔记(九):数据库客户

python在linux中输出带颜色的文字的方法

浅析python 内置字符串处理函数的使用方法

python实现DNS正向查询、反向查询的例子

python代码检查工具pylint 让你的python更

python中getattr函数使用方法 getattr实现

python fabric实现远程操作和部署示例

python计算程序开始到程序结束的运行时间

python不带重复的全排列代码

热 点 排 行

Python入门教程 超详细1小时学会

python 中文乱码问题深入分析

比较详细Python正则表达式操作指

Python字符串的encode与decode研

Python open读写文件实现脚本

Python enumerate遍历数组示例应

Python 深入理解yield

Python+Django在windows下的开发

python 字符串split的用法分享

python 文件和路径操作函数小结

篇3:Python Deque 模块使用详解

最近更 新

python之模拟鼠标键盘动作具体实现

python将多个文本文件合并为一个文本的代

python发送arp欺骗攻击代码分析

Python 字符串操作方法大全

天翼开放平台免费短信验证码接口使用实例

Python3.x和Python2.x的区别介绍

Python实现端口复用实例代码

python条件和循环的使用方法

tornado框架blog模块分析与使用

Python struct模块解析

热 点 排 行

Python入门教程 超详细1小时学会

python 中文乱码问题深入分析

比较详细Python正则表达式操作指

Python字符串的encode与decode研

Python open读写文件实现脚本

Python enumerate遍历数组示例应

Python 深入理解yield

Python+Django在windows下的开发

python 文件和路径操作函数小结

python 字符串split的用法分享

篇4:python使用正则表达式检测密码强度源码

-02-02python实现360的字符显示界面

2014-06-06python网络编程学习笔记(七):HTML和XHTML解析(HTMLParser、Beau

-11-11Python3 入门教程 简单但比较不错

-11-11python从ftp下载数据保存实例

2014-06-06Python学习笔记(一)(基础入门之环境搭建)

2014-04-04python生成随机验证码(中文验证码)示例

2014-04-04Python操作sqlite3快速、安全插入数据(防注入)的实例

2014-06-06python k-近邻算法实例分享

-07-07python下如何让web元素的生成更简单的分析

2013-09-09Python 命令行非阻塞输入的小例子

篇5:python使用正则表达式检测密码强度源码

最近更 新

python实现哈希表

python使用cookielib库示例分享

go和python调用其它程序并得到程序输出

python基础教程之元组操作使用详解

pyqt和pyside开发图形化界面

从零学python系列之从文件读取和保存数据

使用Python获取CPU、内存和硬盘等windown

python将html转成PDF的实现代码(包含中文

python获取beautifulphoto随机某图片代码

Python Web开发模板引擎优缺点总结

热 点 排 行

Python入门教程 超详细1小时学会

python 中文乱码问题深入分析

比较详细Python正则表达式操作指

Python字符串的encode与decode研

Python open读写文件实现脚本

Python enumerate遍历数组示例应

Python 深入理解yield

Python+Django在windows下的开发

python 文件和路径操作函数小结

python 字符串split的用法分享

篇6:比较详细Python正则表达式操作指南(re使用)

最近更 新

python合并文本文件示例

Python设计模式之代理模式实例

pytyon 带有重复的全排列

Python中的yield浅析

python网络编程学习笔记(九):数据库客户

Python操作Mysql实例代码教程在线版(查询

python函数返回多个值的示例方法

Python中的jquery PyQuery库使用小结

python设置检查点简单实现代码

Python translator使用实例

热 点 排 行

Python入门教程 超详细1小时学会

python 中文乱码问题深入分析

比较详细Python正则表达式操作指

Python字符串的encode与decode研

Python open读写文件实现脚本

Python enumerate遍历数组示例应

Python 深入理解yield

Python+Django在windows下的开发

python 字符串split的用法分享

python 文件和路径操作函数小结

篇7:Python模块学习re 正则表达式

最近更 新

本地文件上传到七牛云服务器示例(七牛云存

urllib2自定义opener详解

python发送邮件的实例代码(支持html、图片

python的urllib模块显示下载进度示例

Python程序设计入门(2)变量类型简介

python读取浮点数和读取文本文件示例

python根据距离和时长计算配速示例

python文件读写并使用mysql批量插入示例分

Python笔记(叁)继续学习

python模拟登录百度贴吧(百度贴吧登录)实

热 点 排 行

Python入门教程 超详细1小时学会

python 中文乱码问题深入分析

比较详细Python正则表达式操作指

Python字符串的encode与decode研

Python open读写文件实现脚本

Python enumerate遍历数组示例应

Python 深入理解yield

Python+Django在windows下的开发

python 字符串split的用法分享

python 文件和路径操作函数小结

【Python正则表达式的七个使用详解】相关文章:

1.Python模块学习re 正则表达式

2.Python中encode方法的使用简介

3.python基础教程之数字处理(math)模块详解

4.python使用cStringIO实现临时内存文件访问的方法

5.Python完全新手教程

6.英语语法详解

7.Perl 中的正则表达式自动测试脚本语言

8.党支部七个职责

9.Python函数返回值实例分析

10.python操作xml文件示例

下载word文档
《Python正则表达式的七个使用详解.doc》
将本文的Word文档下载到电脑,方便收藏和打印
推荐度: 评级1星 评级2星 评级3星 评级4星 评级5星
点击下载文档

文档为doc格式

  • 返回顶部