如何优雅的使用Python的正则表达式.

在正则表达式中你需要指定一些规则命令来描述你希望匹配到的字符串集合 , 这些字符串集合可能包含英文句子 , e-mail地址 , Tex命令 , 或者任何东西.

Python中的正则表达式 是用C语言写的 , 所以效率非常高 .

大多数的字符会匹配他们自身 , 举个例子 ,  正则表达式"FishC""将完全匹配字符串"FishC"(当然也可以启用不区分大小写 , 这样就可以用"FishC" 来匹配到 fISHc了).

上面说大部分的字符会匹配自身是因为 , 有所谓的 元字符 他们并不能匹配自身(需要用反斜杠 让字符本身的功能失效) 下面会讲解元字符的作用 . 这里给出完整的元字符列表 [  . ^ $ * + ?  { }  [ ] \ | () ] 这些元字符十分的重要如果没有这些元字符  正则表达式就和find()方法 一样的 不好用了.

开始解释 []

他们用于制定一个字符类用于存放你需要匹配的字符集 , 可以单独列出需要匹配的字符 , 也可以通过两个字符和一个横杠 - 来指定范围 . 例如[abc]会匹配字符a,b,c;[a-c]可以实现相同的功能 , 或者使用范围来表示和前者相同的字符集和 , 如果你知相匹配小写字符 你的re 可以写成 [a-z].      需要注意的是 元字符  在[]中是不会有特殊功能的 (没有有功能的必要).在字符类中他们值匹配自身

你还可以匹配方括号中没有列出来的字符 , 如果你想实现这个功能可以 [^5] 这样就会匹配除了5以外的其他所有字符 . 当然最重要的 元字符 是属于 \ 如果你想匹配 [ 或 \ 你可以 \[或\\ . \

下面举一个例子 . \w   可以匹配 任何单词字符 , 如果正则表达式以字节的形式表示 , 这相当于类 [a-z A-Z 0-9]   如果正则表达式是一个字符串 , \w 会匹配所有 Unicode 数据库中标记位字母的字符 , 你可以在编译正则表达式的时候

通过re.ASCll来进一步限制\w的范围 .

下面是一些反斜杠加字符构成的特殊含义 .    

上面表中的字符也可以包含在一个字符类中,并且拥有一样的含义 [\s,.],意味着可以匹配任何非空白自负和 "," "."

最后一个是 "." ,他将匹配任何出来换行符以外的字符 . 如果设置了 re.DOTALL的标志 , "." 也将匹配包含换行符在内的任何字符 .

下面介绍一下 "*"

时间: 2024-10-07 07:10:54

如何优雅的使用Python的正则表达式.的相关文章

python 中正则表达式

. 匹配除换行符以外的任意字符 \w 匹配字母或数字或下划线或汉字 \s 匹配任意的空白符 \d 匹配数字 \b 匹配单词的开始或结束 ^ 匹配字符串的开始 $ 匹配字符串的结束 代码/语法 说明 * 重复零次或更多次 + 重复一次或更多次 ? 重复零次或一次 {n} 重复n次 {n,} 重复n次或更多次 {n,m} 重复n到m次 [aeiou]就匹配任何一个英文元音字母,[.?!]匹配标点符号(.或?或!). [0-9]代表的含意与\d就是完全一致的:一位数字:同理[a-z0-9A-Z_]也完

python用正则表达式怎么查询unicode码字符

import re data = open('a.txt') fh = open('b.txt', 'w') """Search the string begining with '['""" p = re.compile(r'\s*[\u3010]') for each_d in data: if re.match('\s*3\d{4}', each_d): each_d = each_d.strip() print(each_d + ': '

【python】正则表达式

在python中,所有和正则表达式相关的功能都包含在re模块中. $表示字符串的末尾,^表示字符串的开始,原始字符串:字符串添加前缀r,表示字符串中的所有字符都不转义.\b表示单词的边界必须在这里. s="100 BROAD" re.sub('ROAD$','RD',s) 结果:'100 BRD' re.sub(r'\bROAD$','RD',s) 结果:100 BROAD M?可选地匹配单个字符,要么一个M,要么没有M.re模块的关键是一个search函数,该函数由两个参数,一个是正

python使用正则表达式文本替换

2D客户端编程从某种意义上来讲就是素材组织,所以,图片素材组织经常需要批量处理,python一定是最佳选择,不过是win/linux/mac都有一个简单的运行环境 举两个应用场景: 如果不是在某个文件夹里面则将文件夹名称插入前面 所有的文件名名称加上一个前缀 直接看代码吧 # encoding: UTF-8 import re # 将正则表达式编译成Pattern对象 p = re.compile(r'(?P<folder>(\w+/)*)(?P<filename>\w+\.png

Python使用正则表达式替换源码前序号

从博客园或其它地方拷贝代码,经常前面有代码序号,像下面这个样子: 1 wbContent.Navigate(vURL); 2  3     Result:=GetHtml(wbContent); 4  5     while not ContainsText(Result,'共找到') do 6     begin 7       Sleep(100); 8       Application.ProcessMessages; 9       Result:=GetHtml(wbContent)

python study - 正则表达式

第 7 章 正则表达式 7.1. 概览 7.2. 个案研究:街道地址 7.3. 个案研究:罗马字母 7.3.1. 校验千位数 7.3.2. 校验百位数 7.4. 使用 {n,m} 语法 7.4.1. 校验十位数和个位数 7.5. 松散正则表达式 7.6. 个案研究:解析电话号码 7.7. 小结 正则表达式是搜索.替换和解析复杂字符模式的一种强大而标准的方法.如果你曾经在其他语言 (如 Perl) 中使用过它,由于它们的语法非常相似,你仅仅阅读一下 re 模块的摘要,大致了解其中可用的函数和参数就

Python爬虫-正则表达式

正则表达式 只提取关注的数据,进行数据赛选 原子: 基本组成单位 普通的字符 非打印支付 通用字符 普通的字符 >>> import re >>> pat="yue" >>> string="http://yum.iqianyue.com" >>> rst1=re.search(pat,string) >>> print(rst1) <_sre.SRE_Match obj

python的正则表达式 re

python的正则表达式 re 本模块提供了和Perl里的正则表达式类似的功能,不关是正则表达式本身还是被搜索的字符串,都可以是Unicode字符,这点不用担心,python会处理地和Ascii字符一样漂亮. 正则表达式使用反斜杆(\)来转义特殊字符,使其可以匹配字符本身,而不是指定其他特殊的含义.这可能会和python字面意义上的字符串转义相冲突,这也许有些令人费解.比如,要匹配一个反斜杆本身,你也许要用'\\\\'来做为正则表达式的字符串,因为正则表达式要是\\,而字符串里,每个反斜杆都要写

Python re正则表达式模块学习【转】

感谢原作者,本文转自:http://www.cnblogs.com/huxi/archive/2010/07/04/1771073.html 博主还有一些比较好的python文档在此一并推荐,可以移步查看. 文介绍了Python对于正则表达式的支持,包括正则表达式基础以及Python正则表达式标准库的完整介绍及使用示例.本文的内容不包括如何编写高效的正则表达式.如何优化正则表达式,这些主题请查看其他教程. 注意:本文基于Python2.4完成:如果看到不明白的词汇请记得百度谷歌或维基,whate