python之(re)正则表达式上
python正则表达式知识预备
正则表达式使用反斜杠" \ "来代表特殊形式或用作转义字符,这里跟Python的语法冲突,因此,Python用" \\\\ "表示正则表达式中的" \ ",因为正则表达式中如果要匹配" \ ",需要用\来转义,变成" \\ ",而Python语法中又需要对字符串中每一个\进行转义,所以就变成了" \\\\ "。
上面的写法是不是觉得很麻烦,为了使正则表达式具有更好的可读性,Python特别设计了原始字符串(raw string),需要提醒你的是,在写文件路径的时候就不要使用raw string了,这里存在陷阱。raw string就是用'r'作为字符串的前缀,如 r"\n":表示两个字符"\"和"n",而不是换行符了。Python中写正则表达式时推荐使用这种形式。
问题:如何匹配到‘\com’
# r9 = re.search('\\\\', 'www.run\comoob')
# print(r9) #匹配到‘\’ '\\\\' python 将其翻译为'\\' re 模块将其编译为'\'
上面太麻烦了,明显不符合实际操作,看下面的:
r10 = re.search(r'\\com', 'www.run\comoob') #加r , 表示python 不翻译,re 翻译
print(r10)
#f = open("c:\abc.txt") #错误 应该是f = open("c:\\abc.txt")
r7 = re.search(r'\\com', 'www.run\comoob') #注意:匹配到'\com' 翻译到屏幕是'\\com'
print(r7)
学习正则表达式
接下来系统学习正则表达式,文章有点长,希望不懂的同学可以耐心看下去,我会多举例的
先大致看下,后面会举例:
字符:
. 匹配除换行符以外的任意字符
\w 匹配字母或数字或下划线或汉字
\s 匹配任意的空白符
\d 匹配数字
\b 匹配单词的开始或结束
^ 匹配字符串的开始
$ 匹配字符串的结束
次数:
* 重复零次或更多次
+ 重复一次或更多次
? 重复零次或一次
{n} 重复n次
{n,} 重复n次或更多次
{n,m} 重复n到m次
正则表达式本身就是小型编程语言,使用之前肯定要先导入啦,下面实例默认都是导入的。 一、了解findout,及字符
1. findout 把匹配结果通过列表返回
r =re.findall('zcl', 'fzclfjfrijzclfeizcfj')
print(r) #['zcl', 'zcl']
2. . 匹配到除换行符以外的任一个字符
r1 =re.findall('z.l', 'fzolfjfrijzclfeizcfj')
print(r1) #['zol', 'zcl']
r1 =re.findall('z.l', 'fz\nlfjfrijzclfeizcfj')
print(r1) #['zcl']
3. ^ (shift+6)区配到以 xx字符开头
r2 =re.findall('^z.l', 'fz\nlfjfrijzclfeizcfj')
print(r2) #[]
r3 =re.findall('^z.l', 'zcllfz\nlfjfrijzclfeizcfj')
print(r3) #['zcl']
4. $ 匹配到以xx结束的字符
r4 =re.findall('z.l$', 'zcllfz\nlfjfrijzclfeizcfj')
print(r4) #[]
r5 =re.findall('z.l$', 'zcllfz\nlfjfrijzclfeizcfjzcl')
print(r5) #['zcl']
5. * 区配*前面的字符0到多次
+ 重复一次或更多次
r6 =re.findall('z.*l', 'zcgfchthllfz\nlfjfrijzclfeizcfjzcl')
print(r6) #['zcgfchthll', 'zclfeizcfjzcl'] r7 =re.findall('z.+l', 'zcgfchthfz\nlfjfrijzcfeizcfjzc')
print(r7) #[]
6. {n} 重复n次
{n,m} 重复n到m次
{n,} 重复n次或更多次
r8 = re.findall('zc{3}l', 'zccclgfchthfz\nlfjfrijzcfeizcfjzc')
print(r8) #['zcccl']
7. [bc] 匹配b或c
r9 = re.findall('a[bd]c', 'dfjabdcdjfabcdf')
print(r9)
8. [a-z] 匹配a至z任意一个
r9 = re.findall('a[a-z]c', 'dfjabdcdjfatcdf')
print(r9) #['atc']
9. [] 里面仍有功能有三个: [a-z] [\d]区配数字 [^] 非
r10 = re.findall('a[^f]d', "afd")
print(r10) #[]
r11 = re.findall('a[^f]d', "ard")
print(r11) #['ard']
r12 = re.findall(r'a\df', "a8f")
print(r12) #['a8f']
欢迎转发!
This is zcl‘s article! Thanks for your support!
文章出处:http://www.cnblogs.com/0zcl
作者:zcl
python之(re)正则表达式上的更多相关文章
- Python高手之路【五】python基础之正则表达式
下图列出了Python支持的正则表达式元字符和语法: 字符点:匹配任意一个字符 import re st = 'python' result = re.findall('p.t',st) print( ...
- python基础之正则表达式
正则表达式语法 正则表达式 (或 RE) 指定一组字符串匹配它;在此模块中的功能让您检查一下,如果一个特定的字符串匹配给定的正则表达式 (或给定的正则表达式匹配特定的字符串,可归结为同一件事). 正则 ...
- Python::re 模块 -- 在Python中使用正则表达式
前言 这篇文章,并不是对正则表达式的介绍,而是对Python中如何结合re模块使用正则表达式的介绍.文章的侧重点是如何使用re模块在Python语言中使用正则表达式,对于Python表达式的语法和详细 ...
- python的re正则表达式模块学习
python中re模块的用法 Python 的 re 模块(Regular Expression 正则表达式)提供各种正则表达式的匹配操作,在文本解析.复杂字符串分析和信息提取时是一个非常有用的工 ...
- Python基础之 正则表达式指南
本文介绍了Python对于正则表达式的支持,包括正则表达式基础以及Python正则表达式标准库的完整介绍及使用示例.本文的内容不包括如何编写高效的正则表达式.如何优化正则表达式,这些主题请查看其他教程 ...
- 使用python爬取MedSci上的期刊信息
使用python爬取medsci上的期刊信息,通过设定条件,然后获取相应的期刊的的影响因子排名,期刊名称,英文全称和影响因子.主要过程如下: 首先,通过分析网站http://www.medsci.cn ...
- Python系列之正则表达式详解
Python 正则表达式模块 (re) 简介 Python 的 re 模块(Regular Expression 正则表达式)提供各种正则表达式的匹配操作,和 Perl 脚本的正则表达式功能类似,使用 ...
- 【转载】Python中的正则表达式教程
本文http://www.cnblogs.com/huxi/archive/2010/07/04/1771073.html 正则表达式经常被用到,而自己总是记不全,转载一份完整的以备不时之需. 1. ...
- Python中的正则表达式教程
本文http://www.cnblogs.com/huxi/archive/2010/07/04/1771073.html 正则表达式经常被用到,而自己总是记不全,转载一份完整的以备不时之需. 1. ...
随机推荐
- ios UIWebView 在开发中加载文件
UIWebView 在实际应用中加载文件的时候,有两种情况, 1. 实行在线预览 , 2. 下载到本地,再查看 如果是第一种情况: NSURL *url = [NSURL URLWithString: ...
- swift中Range的使用书名
在swift中Range有两种用法 1.把字符串转换成NSString来使用 //这里是把swift的字符换转换成了nsstring 使用 let str :NSString = text.strin ...
- 【解决】查询无法完成,因为其包含的查找列数已超过管理员强制实施的查找列阈值。Error code=0x80070093; Error source=Groove
前因: 修改了SharePoint Server 2013 下面的文档库的名称,原先2个汉字,现在8个汉字.结果,SkyDrive Pro 就无法同步了,无论是停止重新同步还是手动填写进行同步都不可以 ...
- 从 github 上 fork repositories 后,如何和原仓库同步?
1. 首先要先确定一下是否建立了主repo的远程源: git remote -v 2. 如果里面只能看到你自己的两个源(fetch 和 push),那就需要添加主repo的源: git remote ...
- Tomcat创建HTTPS访问,java访问https
一 https和ssL HTTPS(全称:Hyper Text Transfer Protocol over Secure Socket Layer),是以安全为目标的HTTP通道,简单讲是HTTP的 ...
- 从零开始,搭建博客系统MVC5+EF6搭建框架(4)上,前后台页面布局页面实现,介绍使用的UI框架以及JS组件
一.博客系统进度回顾以及页面设计 1.1页面设计说明 紧接前面基础基本完成了框架搭建,现在开始设计页面,前台页面设计我是模仿我博客园的风格来设计的,后台是常规的左右布局风格. 1.2前台页面风格 主页 ...
- ActiveX(四) mshtml 命名空间 重要接口简介
在上一篇随笔 ActiveX(三)ActiveX 调用 Js 中,我们已经可以获得js中window对象的强类型接口.即 mshtml.IHTMLWindow2 ,通过该接口.我们可以调用js函数.那 ...
- 执行后台任务的利器——Hangfire
今年1月31日,在微软的MVP 2015社区大讲堂上,我给大家分享了一个演讲:在ASP.NET应用中执行后台任务.其中介绍了三种技术的应用:QueueBackgroundWorkItem.Hangfi ...
- linq lambda left join
//var list = table1.Join(table2, ee => ee.Id, ff => ff.table1_Id, (ee, ff) => new { ee, ff ...
- jquery完整弹窗代码
</html> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http ...