- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Python正则表达式的七个使用范例详解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
作为一个概念而言,正则表达式对于Python来说并不是独有的。但是,Python中的正则表达式在实际使用过程中还是有一些细小的差别.
本文是一系列关于Python正则表达式文章的其中一部分。在这个系列的第一篇文章中,我们将重点讨论如何使用Python中的正则表达式并突出Python中一些独有的特性.
我们将介绍Python中对字符串进行搜索和查找的一些方法。然后我们讲讨论如何使用分组来处理我们查找到的匹配对象的子项.
我们有兴趣使用的Python中正则表达式的模块通常叫做‘re'.
1
|
>>>
import
re
|
1. Python中的原始类型字符串 。
Python编译器用‘\'(反斜杠)来表示字符串常量中的转义字符.
如果反斜杠后面跟着一串编译器能够识别的特殊字符,那么整个转义序列将被替换成对应的特殊字符(例如,‘\n'将被编译器替换成换行符).
但这给在Python中使用正则表达式带来了一个问题,因为在‘re'模块中也使用反斜杠来转义正则表达式中的特殊字符(比如*和+).
这两种方式的混合意味着有时候你不得不转义转义字符本身(当特殊字符能同时被Python和正则表达式的编译器识别的时候),但在其他时候你不必这么做(如果特殊字符只能被Python编译器识别).
与其将我们的心思放在去弄懂到底需要多少个反斜杠,我们可以使用原始字符串来替代.
原始类型字符串可以简单的通过在普通字符串的双引号前面加一个字符‘r'来创建。当一个字符串是原始类型时,Python编译器不会对其尝试做任何的替换。本质上来讲,你在告诉编译器完全不要去干涉你的字符串.
1
2
3
4
5
6
7
|
>>> 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查找 – 匹配开始 。
让我们先来看一下match()方法。match()方法的工作方式是只有当被搜索字符串的开头匹配模式的时候它才能查找到匹配对象.
举个例子,对字符串‘dog cat dog'调用mathch()方法,查找模式‘dog'将会匹配:
1
2
3
4
5
|
>>> 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',则不会找到匹配.
1
2
|
>>> re.match(r
'cat'
,
'dog cat dog'
)
>>>
|
3. 使用re.search查找 – 匹配任意位置 。
search()方法和match()类似,不过search()方法不会限制我们只从字符串的开头查找匹配,因此在我们的示例字符串中查找‘cat'会查找到一个匹配:
1
2
3
|
search(r
'cat'
,
'dog cat dog'
)
>>> match.group(
0
)
'cat'
|
然而search()方法会在它查找到一个匹配项之后停止继续查找,因此在我们的示例字符串中用searc()方法查找‘dog'只找到其首次出现的位置.
1
2
3
|
>>> match
=
re.search(r
'dog'
,
'dog cat dog'
)
>>> match.group(
0
)
'dog'
|
4. 使用 re.findall – 所有匹配对象 。
目前为止在Python中我使用的最多的查找方法是findall()方法。当我们调用findall()方法,我们可以非常简单的得到一个所有匹配模式的列表,而不是得到match的对象(我们会在接下来更多的讨论match对象)。对我而言这更加简单。对示例字符串调用findall()方法我们得到:
1
2
3
|
[
'dog'
,
'dog'
]
>>> re.findall(r
'cat'
,
'dog cat dog'
)
[
'cat'
]
|
5. 使用 match.start 和 match.end 方法 。
那么,先前search()和match()方法先前返回给我们的‘match'对象”到底是什么呢?
和只简单的返回字符串的匹配部分不同,search()和match()返回的“匹配对象”,实际上是一个关于匹配子串的包装类.
先前你看到我可以通过调用group()方法得到匹配的子串,(我们将在下一个部分看到,事实上匹配对象在处理分组问题时非常有用),但是匹配对象还包含了更多关于匹配子串的信息.
例如,match对象可以告诉我们匹配的内容在原始字符串中的开始和结束位置:
1
2
3
4
5
|
>>> match
=
re.search(r
'dog'
,
'dog cat dog'
)
>>> match.start()
0
>>> match.end()
3
|
知道这些信息有时候非常有用.
6. 使用 mathch.group 通过数字分组 。
就像我之前提到的,匹配对象在处理分组时非常得心应手.
分组是对整个正则表达式的特定子串进行定位的能力。我们可以定义一个分组做为整个正则表达式的一部分,然后单独的对这部分对应匹配到的内容定位.
让我们来看一下它是怎么工作的:
1
|
>>> contactInfo
=
'Doe, John: 555-1212'
|
我刚才创建的字符串类似一个从某人的地址本里取出来的一个片段。我们可以通过这样一个正则表达式来匹配这一行:
1
2
|
>>> re.search(r
'\w+, \w+: \S+'
, contactInfo)
<_sre.SRE_Match
object
at
0xb74e1ad8
<
|
通过用圆括号来(字符‘('和‘)')包围正则表达式的特定部分,我们可以对内容进行分组然后对这些子组做单独处理.
1
|
>>> match
=
re.search(r
'(\w+), (\w+): (\S+)'
, contactInfo)
|
这些分组可以通过用分组对象的group()方法得到。它们可以通过其在正则表达式中从左到右出现的数字顺序来定位(从1开始):
1
2
3
4
5
6
|
>>> match.group(
1
)
'Doe'
>>> match.group(
2
)
'John'
>>> match.group(
3
)
'555-1212'
|
组的序数从1开始的原因是因为第0个组被预留来存放所有匹配对象(我们在之前学习match()方法和search()方法到时候看到过).
1
2
|
>>> match.group(
0
)
'Doe, John: 555-1212'
|
7. 使用 match.group 通过别名来分组 。
有时候,特别是当一个正则表达式有很多分组的时候,通过组的出现次序来定位就会变的不现实。Python还允许你通过下面的语句来指定一个组名:
>>> match = re.search(r'(?P<last>\w+), (?P<first>\w+): (?P<phone>\S+)', contactInfo) 。
我们还是可以用group()方法获取分组的内容,但这时候我们要用我们所指定的组名而不是之前所使用的组的所在位数.
1
2
3
4
5
6
|
>>> match.group(
'last'
)
'Doe'
>>> match.group(
'first'
)
'John'
>>> match.group(
'phone'
)
'555-1212'
|
这大大加强了代码的明确性和可读性。你可以想像当正则表达式变得越来越复杂,去弄懂一个分组到捕获了什么内容将会变得越来越困难。给你的分组命名将明确的告诉了你和你的读者你的意图.
尽管findall()方法不返回分组对象,它也可以使用分组。类似的,findall()方法将返回一个元组的集合,其中每个元组中的第N个元素对应了正则表达式中的第N个分组.
1
2
|
>>> re.findall(r
'(\w+), (\w+): (\S+)'
, contactInfo)
[(
'Doe'
,
'John'
,
'555-1212'
)]
|
但是,给分组命名并不适用于findall()方法.
在本文中我们介绍了Python中使用正则表达式的一些基础。我们学习了原始字符串类型(还有它能帮你解决的在使用正则表达式中一些头痛的问题)。我们还学习了如何适使用match(), search(), and findall()方法进行基本的查询,以及如何使用分组来处理匹配对象的子组件.
和往常一样,如果想查看更多关于这个主题的内容,re模块的Python官方文档是一个非常好的资源.
在以后的文章中,我们将更深入的讨论Python中正则表达式的应用。我们将更加全面的学习匹配对象,学习如何使用它们在字符串中做替换,甚至使用它们从文本文件中去解析Python数据结构.
本文由 伯乐在线 - 左手的灵魂 翻译自 thegeekstuff.
最后此篇关于Python正则表达式的七个使用范例详解的文章就讲到这里了,如果你想了解更多关于Python正则表达式的七个使用范例详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
在我看来,jQuery 似乎并不是作为 OOP 框架编写的,它似乎太短,而且不够详细。我的想法是否正确?如果它不是以 OOP 形式编写的,那么他们使用的是什么方法/范式? 最佳答案 我怀疑该方法是:使
假设我们有两条 CD 信息 标题 艺术家 国家 公司 价格 年份 Empire Burlesque
开始学习之前,我们先来看一个简单的 SVG 范例, 包含了 SVG 的一些基本要素 简单的 SVG 实例 我们来画一个简单的 SVG 圆形 这里是SVG文件(SVG文件的保存与SVG扩展) &
下面这些范例演示了 XML 文件、XML 格式化和 XML 转换 ( XSLT ) 还演示了与 XML 一起使用的 JavaScript ( AJAX ) 查看 XML 文件 1、 查看一个简单
本章节,我们通过一些范例来学习一些基础的 XPath 语法 XPath 范例文档 我们将在下面的例子中使用这个 XML 文档 books.xml <?xml version="
在XLink和 XPointer 语法 章节,我们讲到可以在 xlink:href 属性中把 XPointer 部分添加到 URL 后面,这样就可以导航到文档中某个具体的位置 现在,让我们通过一个范
我的 Android 模拟器包含“API 演示”列表,包括 App->Device Admin 部分中一个漂亮的密码 PIN 表单(经过验证)。 知道在哪里可以找到源代码吗?或者有人知道用户 PIN
iDevRecipes是一个很棒的网站,它详细介绍了一些流行的和特定的 iPhone 组件是如何开发的。我想知道 SO 工作人员是否知道其他类似的网站?这将对所有 iOS 开发人员有很大帮助。 最佳答
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我正在尝试使用 React 创建 Aurelia 自定义元素,方法是按照 Aurelia Q & A 上的示例进行操作并发生以下异常: Potentially unhandled rejection
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: Real world examples of @optional protocol methods 最近我开
我正在尝试使用多线程在 Java (Swing) 中实现 MVC 范例。目前,我正在用 Observer 类扩展 View 类,用 Observable 类扩展 Model 类,并且它工作正常(我的代
场所: 理想情况下,一种语言中的程序应尝试匹配该语言所归属的范例的方式。 在 Swift 中,这些范例主要是面向协议(protocol)的编程,其次是函数式编程。 出于兼容性和互操作性的原因,Swif
在 MVC 中,一个模型可以有多个 View ,而在 WPF 中,XAML 代码隐藏模型严格限制为 1 个 XAML( View ),难道 WPF/XAML 从一开始就没有 MVC 方面的缺陷吗? 最
我有一个类,比方说,它计算一个人的保险风险,并且在计算过程中计算了一些其他变量。稍后我需要访问风险和其他变量。 class InsuranceRiskModel: self.risk = No
我是一名优秀的程序员,十分优秀!