今日任务:

五周三次课(11月15日)
11.4 re的matche方法和search方法
11.5 re的split,findall,finditer方法
11.6 re的match对象

match方法

match(string[, pos[, endpos]])

string:匹配使用的文本,

pos: 文本中正则表达式开始搜索的索引。及开始搜索string的下标

endpos: 文本中正则表达式结束搜索的索引。

如果不指定pos,默认是从开头开始匹配,如果匹配不到,直接返回None

import re

pattern = re.compile(r'\w*(hello w.*)(hello l.*)')

result = pattern.match(r'aahello world hello ling')

print(result)

result2 = pattern.match(r'hello world hello ling')

print(result2.groups())

结果:

None

('hello world ', 'hello ling')

解释:如果不指定pos的话,默认是从字符串开始位置匹配,匹配不到就返回None,以上所有的pattern都是一个match对象。

search方法

search(string[, pos[, endpos]])

这个方法用于查找字符串中可以匹配成功的子串。从string的pos下标处起尝试匹配pattern,如果pattern结束时仍可匹配,则返回一个Match对象;若无法匹配,则将pos加1后重新尝试匹配;直到pos=endpos时仍无法匹配则返回None。下面看个列子:

import re

pattern = re.compile(r'(hello w.*)(hello l.*)')

result1 = pattern.search(r'aahello world hello ling')

print(result1.groups())

结果:

('hello world ', 'hello ling')

解释:

split方法

split(string[, maxsplit])

按照能够匹配的子串将string分割后返回列表。maxsplit用于指定最大分割次数,不指定将全部分割。

import re

p = re.compile(r'\d+')

print(p.split('one1two2three3four4'))

结果:

['one', 'two', 'three', 'four', '']

解释:直接把p的正则当成是分隔符,然后把最后的字符串用p进行分割,然后返回回去

findall方法

findall(string[, pos[, endpos]]) 

搜索string,以列表形式返回全部能匹配的子串.

import re

p = re.compile(r'\d+')

print(findall('one1two2three3four4'))

结果:

['1', '2', '3', '4']

结果:findall是把匹配到的字符串最后一列表的形式返回回去

finditer方法

finditer(string[, pos[, endpos]])

搜索string,返回一个顺序访问每一个匹配结果(Match对象)的迭代器。

import re

p = re.compile(r'\d+')

print(type(p.finditer('one1two2three3four4')))

for m in p.finditer('one1two2three3four4'):

print(type(m))

print(m.group())

结果:<type 'callable-iterator'>

<type '_sre.SRE_Match'>

1

<type '_sre.SRE_Match'>

2

<type '_sre.SRE_Match'>

3

<type '_sre.SRE_Match'>

4

解释:

p.finditer('one1two2three3four4')是一个迭代器,而返回的每个m都是match对象

sub方法

sub(repl, string[, count]) 

使用repl替换string中每一个匹配的子串后返回替换后的字符串。

当repl是一个字符串时,可以使用\id或\g<id>、\g<name>引用分组,但不能使用编号0。

当repl是一个方法时,这个方法应当只接受一个参数(Match对象),并返回一个字符串用于替换(返回的字符串中不能再引用分组)。

count用于指定最多替换次数,不指定时全部替换。

import re

p = re.compile(r'(\w+) (\w+)')

s = 'i say, hello world!'

print(p.sub(r'\2 \1', s))

def func(m):

return m.group(1).title() + ' ' + m.group(2).title()

print(p.sub(func, s))

结果:

say i, world hello!

I Say, Hello World!

解释:

\(id)就是匹配的括号的内容,id从默认从1开始计数

m.group(1)是一个字符串,调用字符串的title()方法,所有单词的搜字母大写。

match匹配对象

Match对象是一次匹配的结果,包含了很多关于此次匹配的信息,可以使用Match提供的可读属性或方法来获取这些信息。上面的过程中多次使用了match对象,调用了他的group()和groups()等方法。

例子

import re

prog = re.compile(r'(?P<tagname>abc)(.*)(?P=tagname)')

result1 = prog.match('abclfjlad234sjldabc')

print(result1)

print(result1.groups())

print result1.group('tagname')

print(result1.group(2))

print(result1.groupdict())

结果:

<_sre.SRE_Match object at 0x0000000002176E88>

('abc', 'lfjlad234sjld')

abc

lfjlad234sjld

{'tagname': 'abc'}

解释:

1,我们可以看到result1已经由字符串转换成了一个正则对象。

2,resule.groups()可以查看出来所有匹配到的数据,每个()是一个元素,最终返回一个tuple

3,group()既可以通过下标(从1开始)的方式访问,也可以通过分组名进行访问。

4,groupdict只能显示有分组名的数据

group([group1, …]): 
获得一个或多个分组截获的字符串;指定多个参数时将以元组形式返回。group1可以使用编号也可以使用别名;编号0代表整个匹配的子串;不填写参数时,返回group(0);没有截获字符串的组返回None;截获了多次的组返回最后一次截获的子串。

groups([default]): 
以元组形式返回全部分组截获的字符串。相当于调用group(1,2,…last)。default表示没有截获字符串的组以这个值替代,默认为None。

groupdict([default]): 
返回以有别名的组的别名为键、以该组截获的子串为值的字典,没有别名的组不包含在内。default含义同上。

转载于:https://www.cnblogs.com/zhuntidaoren/p/7841250.html

20171115_Python学习五周三次课相关推荐

  1. 20171113_Python学习五周一次课

    任务: 五周一次课(11月13日) 10.8.1 json(上) 10.8.2 json(下) 笔记: Json简介:Json,全名 JavaScript Object Notation,是一种轻量级 ...

  2. 七周三次课(1月24日) 10.11 Linux网络相关 10.12 firewalld和netfilter 10.13 netfilter5表5链介绍 10.14 iptables语法...

    七周三次课(1月24日) 10.11 Linux网络相关 10.12 firewalld和netfilter 10.13 netfilter5表5链介绍 10.14 iptables语法 ====== ...

  3. 深度学习笔记第一门课第一周:深度学习引言

    本文是吴恩达老师的深度学习课程[1]笔记部分. 作者:黄海广[2] 主要编写人员:黄海广.林兴木(第四所有底稿,第五课第一二周,第三周前三节).祝彦森:(第三课所有底稿).贺志尧(第五课第三周底稿). ...

  4. Python-opencv学习第二十九课:高斯双边模糊

    Python-opencv学习第二十九课:高斯双边模糊 文章目录 Python-opencv学习第二十九课:高斯双边模糊 一.学习部分 二.代码部分 1.引入库 2.读入数据 3.完整代码 三.运行结 ...

  5. Qt 5.9.5学习笔记第三节课

    Qt 5.9.5学习笔记第三节课 学习目标 1.Qt资源图标添加和使用 1.1添加资源文件 1.2qmake让资源文件生效 1.3修改widget应用程序窗口ICO 1.3.1第一种方法 1.3.2 ...

  6. 聋校计算机教学案例,聋校语文第五册第一课教学案例

    <聋校语文第五册第一课教学案例>由会员分享,可在线阅读,更多相关<聋校语文第五册第一课教学案例(2页珍藏版)>请在人人文库网上搜索. 1.聋校语文第五册第一课我们的学校第二课时 ...

  7. python学习(第三节课)

    一.创建列表的几种方法 x=list(range(1,100)) x=[ ] for i in range(1,100): x.append(i) x=[i+2 for i in range(1,10 ...

  8. 大数据学习笔记第1课 Hadoop基础理论与集群搭建

    大数据学习笔记第1课 Hadoop基础理论与集群搭建 一.环境准备 二.下载JDK 三.安装JDK 四.下载hadoop 五.安装hadoop集群 六.打通3台服务器的免密登录 七.hadoop集群配 ...

  9. python学习(第二节课)

    一.列表添加元素的几种方法 [1,2,3]+[4,5,6]=[1,2,3,4,5,6]------直接两个列表相加 x.append(v)-------直接列表尾部添加单个元素v x=[1,2,3] ...

最新文章

  1. python加号换行,Python字符串拼接六种方法介绍
  2. 一个android记事本的学习过程记录! (一)
  3. 优化方案电子版_关于小区分支道路整修设计方案的讨论稿(No.2020121)
  4. 最全Java锁详解:独享锁/共享锁+公平锁/非公平锁+乐观锁/悲观锁
  5. Java中的堆和栈的区别
  6. 将markdown文本转换为微信文章格式的解决方案
  7. PHP截取中文字符串的方法
  8. 服务器监视Zabbix 5.0 - 安装部署
  9. Ubuntu18.04 安装 rabbitvcs svn 图形化客户端
  10. TwinCAT3入门教程3——PLC程序变量定义和硬件IO关联
  11. HuaWei ❀ 双协议栈
  12. 2020-09-07(基于控制台的DVD管理系统)
  13. 基于stm32f103c8t6的fft频率计
  14. 最新android版本叫什么,Android版本今年将大更新,迈入10.0时代,新特性曝光
  15. 创业起步阶段需要注意的几点
  16. 泛函分析笔记(二十一) 障碍问题
  17. Java面试题总结(乱序版,来自大厂面试官的MySQL灵魂十连问
  18. 原来光刻机核心技术,来自一个华人
  19. 腾讯云游戏能玩什么,当贝投影仪首发云游戏专区数10款游戏轻松玩
  20. 醉逍遥显示无法更新服务器,醉逍遥

热门文章

  1. [0] 各类图形的数据大小获得
  2. Android Textview控件
  3. word文档插入行号
  4. Grounded Theory and Coding Lecture Notes
  5. 记住,你现在的操作是什么
  6. 找自己的问题和找别人的问题联系和区别
  7. 剑桥大学申请start up签证的有用的网站
  8. 你好,脂肪肝!来自22岁的大学生的体检报告
  9. UNITY Destroy()和DestroyImadiate()都不会立即释放对象内存
  10. 一台linux通过另一台linux访问互联网