码迷,mamicode.com
首页 > 编程语言 > 详细

Python for Informatics 第11章 正则表达式(二)

时间:2016-04-17 22:00:23      阅读:148      评论:0      收藏:0      [点我收藏+]

标签:

忙碌一天,晚上终于有静下来的时间,继续昨天的工作。

11.1 正则表达式的字符匹配

  我们可以用许多其它的特殊字符创建更加强大的正则表达式。最常用的特殊符号是可匹配任何字符的句号(".")。在以下的示例中,正则表达式”F..m:“将匹配”From:”,“Fxxm:",”F12m:“,或者”F!@m:“等类似字符串,因为表达式中间的句号可匹配任何字符。

1 import re
2 hand = open(mbox-short.txt)
3 for line in hand:
4     line = line.rstrip()
5     if re.search(^F..m:, line):
6         print line

  在正则表达式中组合使用表示一个字符任意重复次数的星号(”*")和加号("+")会使表达式特别强大。其中星号表示在查找的字符串中,匹配字符可以重复出现零次以上,而加号则是重复一次以上。

  在下面的示例中,我们使用重复的通配符进一步缩小我们的查找范围:

1 import re
2 hand = open(mbox-short.txt)
3 for line in hand:
4     line = line.rstrip()
5     if re.search(^From:.+@, line):
6         print(line)

  查找字符串“From:.+@”将成功匹配那些以“From:”开头,接着跟着一个以上任意字符,再跟着一个“@”符的行。所以这会匹配类似以下的行:

From: stephen.marquard @uct.ac.za

这个".+"通配符扩展匹配所有从冒号到@符之间的所有字符。

From:.+@

加号和星号符的“一意孤行”的被认为是好的。例如以下的字符串将被外推至最后的@符而匹配:

From:stephen.marquard@uct.ac.za, csev@umich.edu, and cwen @iupui.edu

让星号符和加号符不这么贪婪也是可以的,但是需要添加另外的符号。如何关闭它们贪婪的行为请参看详细的文档。

Python for Informatics 第11章 正则表达式(二)

标签:

原文地址:http://www.cnblogs.com/zhengsh/p/5402151.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!