正则表达式本质就是表示某种规则的一串字符

匹配的规则叫做模式(pattern),模式作用于对象。

模式和对象可以是Unicode或者字节,但是,不能够混用,比如:模式为Unicode,对象为字节,像这样就是错误的!

当有替换需求时,替换字符串的类型也要注意和模式、对象的类型保持一致。(要么都是Unicode,要么都是字节)

下面来谈谈反斜杠(\),我们知道\+字符,可能表示一种特殊的含义,当然也可能表示\和字符2个普通字符。

比如:\d表示数字,\k表示\和k这2个普通字符。

在python中字符串分为2种:

原始字符串(raw string)和字符串

之所以搞个原始字符串,就是来应对转义字符这个大麻烦!

比如:我想表示\和b,如果我用惯性思维写成'\b',那么就傻逼了!因为\将b设置为有特殊含义的字符。

这时必须写成'\\b',但是这种写法太low了!于是搞个原始字符串的东西,前面的可以设置成r'\b'。

虽然加了个r但是相比'\\b'的写法,友好了不少!

所以:'\\\\'和r'\\'是等效的,表示普通字符\。

总结:如果字符中没有\,原始字符串就和字符串一样。

>>> re.findall('a','abkk')
['a']
>>> re.findall(r'a','abkk')
['a']

在正则表达式后面加个?,表示非贪婪匹配(最短匹配)。

re模块中常用的方法:

1、compile()

编译正则表达式的模式为对象模式,这样可以提高执行效率。

语法:

re.compile(r'pattern',[flags])

其中r的含义是不转义字符串,也就是说\t就是\和t。

例如:

import re
hello = "hello,i am tom,nice to konw u."
a = re.compile(r'to')
b = a.findall(hello) ['to','to']

2、match()

匹配的字符串必须按照pattern开头,否则匹配不到。

语法:

re.match(pattern,string,[flags])

例如:

>>> a = "hello"
>>> b = re.match(r'l',a)
>>> b
>>> c = re.match(r'he',a)
>>> c
<_sre.SRE_Match object; span=(0, 2), match='he'>

3、search()

匹配到第一个pattern就返回结果。

语法:

re.search(pattern,string,[flags])

例如:

>>> a = "hellohe"
>>> c = re.search(r'he',a).group()
>>> c
'he'

注:group()方法用来返回一个字符串,因为search()方法返回的是一个match对象。

如果正则中的pattern包含引号,那么需要注意使用\

>>> a = re.search(r'__version__ = [\'"]([^\'"]+)[\'"]',"__version__ = '3.7.0'").group(1)
>>> a
'3.7.0'

单引号中再次使用单引号,必然会造成错误,这个时候,需要在单引号前面加个转义字符(\)。

4、findall()

匹配所有的pattern并返回一个列表。

语法:

re.findall(pattern,string,[flags])

例如:

>>> a = "hello12kk32"
>>> b = re.findall(r'\d+',a)
>>> b
['12', '32']

5、sub()

匹配并替换。

语法:

re.sub(pattern,repl,string,count)

例子:

import re
text = "JGood is a handsome boy, he is cool, clever, and so on..."
print(re.sub(r'\s+', '-', text))
执行结果如下:
JGood-is-a-handsome-boy,-he-is-cool,-clever,-and-so-on... 其中第二个参数是替换后的字符串;本例中为'-' 第四个参数指替换个数。默认为0,表示每个匹配项都替换。

6.re.escape(pattern)

脱离除ascii英文、数字、下划线之外的字符串。

在处理正则时非常有效。

>>> re.escape('www.baidu.com')
'www\\.baidu\\.com'

python模块学习之re的更多相关文章

  1. 【转】Python模块学习 - fnmatch & glob

    [转]Python模块学习 - fnmatch & glob 介绍 fnmatch 和 glob 模块都是用来做字符串匹配文件名的标准库. fnmatch模块 大部分情况下使用字符串匹配查找特 ...

  2. 【目录】Python模块学习系列

    目录:Python模块学习笔记 1.Python模块学习 - Paramiko  - 主机管理 2.Python模块学习 - Fileinput - 读取文件 3.Python模块学习 - Confi ...

  3. Python模块学习filecmp文件比较

    Python模块学习filecmp文件比较 filecmp模块用于比较文件及文件夹的内容,它是一个轻量级的工具,使用非常简单.python标准库还提供了difflib模块用于比较文件的内容.关于dif ...

  4. python模块学习第 0000 题

    将你的 QQ 头像(或者微博头像)右上角加上红色的数字,类似于微信未读信息数量那种提示效果. 类似于图中效果: 好可爱>%<! 题目来源:https://github.com/Yixiao ...

  5. Python模块学习:logging 日志记录

    原文出处: DarkBull    许多应用程序中都会有日志模块,用于记录系统在运行过程中的一些关键信息,以便于对系统的运行状况进行跟踪.在.NET平台中,有非常著名的第三方开源日志组件log4net ...

  6. 解惑Python模块学习,该如何着手操作...

    Python模块 晚上和朋友聊天,说到公司要求精兵计划,全员都要有编程能力.然后C.Java.Python-对于零基础入门的,当然是选择Python的人较多了.可朋友说他只是看了简单的语法,可pyth ...

  7. Python模块学习

    6. Modules If you quit from the Python interpreter and enter it again, the definitions you have made ...

  8. Python模块学习系列

    python模块-time python模块-datetime python模块-OS模块详解

  9. Python模块学习遇到的问题

    Python使用import导入模块时报ValueError: source code string cannot contain null bytes的解决方案 Python使用import导入模块 ...

  10. Python 模块学习:re模块

    今天学习了Python中有关正则表达式的知识.关于正则表达式的语法,不作过多解释,网上有许多学习的资料.这里主要介绍Python中常用的正则表达式处理函数. 方法/属性 作用 match() 决定 R ...

随机推荐

  1. 洛谷 - Sdchr 的邀请赛 T4 信息传递

    (乱搞艹爆正解系列) 对不起,由于博主太弱了,并不会正解的多项式exp(甚至多项式exp我都不会2333). 只能来说一说我是怎么乱搞的啦QWQ 首先这个题最关键的性质是: 一个在原置换 g 中长度为 ...

  2. POJ 2311 Cutting Game (Multi-Nim)

    [题目链接] http://poj.org/problem?id=2311 [题目大意] 给出一张n*m的纸,每次可以在一张纸上面切一刀将其分为两半 谁先切出1*1的小纸片谁就赢了, [题解] 如果切 ...

  3. 【最短路】【spfa】小vijos P1447 Updown

    小vijos P1447 Updown 背景 开启了升降梯的动力之后,探险队员们进入了升降梯运行的那条竖直的隧道,映入眼帘的是一条直通塔顶的轨道.一辆停在轨道底部的电梯.和电梯内一杆控制电梯升降的巨大 ...

  4. mysql replication 复制的一些问题

    1   过大的复制延迟 mysql 的复制延迟是一个常见问题,现在已经有一些解决方案,如淘宝开发的一些工具 2 没有磁盘空间 复制导致磁盘空间塞满,二进制日志.中继日志或临时文件把磁盘塞满,slave ...

  5. Java - Struts框架教程 Hibernate框架教程 Spring框架入门教程(新版) sping mvc spring boot spring cloud Mybatis

    https://www.zhihu.com/question/21142149 http://how2j.cn/k/hibernate/hibernate-tutorial/31.html?tid=6 ...

  6. 使用Spring Cloud Sleuth和Zipkin进行分布式链路跟踪

    原文:http://www.cnblogs.com/ityouknow/p/8403388.html 随着业务发展,系统拆分导致系统调用链路愈发复杂一个前端请求可能最终需要调用很多次后端服务才能完成, ...

  7. 【js】判断浏览器是否IE浏览器

    搜罗各种方法来判断浏览器是否为IE浏览器 1.最简单的[来自:http://www.cnblogs.com/heganlin/p/5889743.html] if(!+[1,]){ layer.msg ...

  8. jquery如何判断元素是否被点击、属性操作、class操作

    1.通过点击事件发生后,改变标志位的值,记录点击状态 function(){ var isClick = false; $('#test').click(function(){isClick = tr ...

  9. Xamarin.Forms 调用 腾讯地图SDK

    Xamarin.Forms研究了好一段时间了,最近一直在学习中,想尝试一下调用其他的SDK,就如腾讯地图SDK(申请容易). 完成此次项目得感谢以下链接: http://www.cnblogs.com ...

  10. C++中的模板学习

    https://www.cnblogs.com/eleclsc/p/5918114.html