python 正则表达式

正则表达式本身是一种小型的、高度专业化的编程语言,而在python中,通过内嵌集成re模块,程序媛们可以直接调用来实现正则匹配。正则表达式模式被编译成一系列的字节码,然后由用C编写的匹配引擎执行。

用法

match()

re.match()尝试从字符串的其实位置匹配一个模式匹配失败返回none
语法:re.match(pattern,string,flags=00)
pattern 匹配的正则表达式
string 要匹配的字符串
flags 标志位,控制正则表达式的匹配方式

1 import re
2 #在起始位置匹配
3 print(re.match('www','www.baidu.com').span())
4 #不再起始位匹配
5 print(re.match('com','www.baidu.com'))

group(num=0)匹配整个表达式的字符串
groups() 返回一个包含所有小组字符串的元组

 1 #!/usr/bin/python
2 import re
3 line = "Cats are smarter than dogs"
4 matchObj = re.match( r'(.*) are (.*?) .*', line, re.M|re.I)
5 if matchObj:
6 print "matchObj.group() : ", matchObj.group()
7 print "matchObj.group(1) : ", matchObj.group(1)
8 print "matchObj.group(2) : ", matchObj.group(2)
9 else:
10 print "No match!!

re.search()

re.search()方法扫描整个字符串并返回第一个成功的匹配
函数语法:re.search(pattern,string,flags=0)
剩下和上面的re.match用法一致

re.match与re.search的区别
re.match只匹配字符串的开始,如果字符串开始不符合正则表达式,则匹配失败,函数返回None;而re.search匹配整个字符串,直到找到一个匹配。

compile()
compile()编译正则表达式模式,返回一个对象模式
格式:re.compile(pattern,flags=0)
pattern:一个字符串形式的正则表达式
flags:可选
re.I 忽略大小写
re.L 表示特殊字符集 \w, \W, \b, \B, \s, \S 依赖于当前环境
re.M 多行模式
re.S 即为 . 并且包括换行符在内的任意字符(. 不包括换行符)
re.U 表示特殊字符集 \w, \W, \b, \B, \d, \D, \s, \S 依赖于 Unicode 字符属性数据库
re.X 为了增加可读性,忽略空格和 # 后面的注释

1 import re
2 tt = "Tina is a good girl, she is cool, clever, and so on..."
3 rr = re.compile(r'\w*oo\w*')
4 print(rr.findall(tt)) #查找所有包含'oo'的单词
5 执行结果如下:
6 ['good', 'cool']

findall()
re.findall遍历匹配,可以获取字符串中所有匹配的字符串,返回一个列表。
格式:re.findall(pattern, string, flags=0)
eg:

1 import re
2 p = re.compile(r'\d+')
3 print(p.findall('xiaohua2020jintian1yue9ri'))
4
5 #执行结果:['2020', '1', '9']

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

split()
按照能够匹配的字串将string分割后返回列表
格式:re.split(pattern,string[,maxsplit])
eg:

1 #按照/d+来匹配分割
2 import re
3 print(re.split('\d+','xiaohuadawang123huahua2020 niubi'))
4 #代码执行结果:['xiaohuadawang', 'huahua', ' niubi']

sub()
使用re替换string中每一个匹配的子串后返回替换后的字符串
re.sub(pattern,repl,string,count)
eg:

1 #\s+匹配 空格部分替换成-
2 import re
3 text="xiaohuadawang from yulinxueyuan xinxianquanxiehui"
4 print(re.sub(r'\s+','-',text))
5 #代码执行结果:
6 #xiaohuadawang-from-yulinxueyuan-xinxianquanxiehui

subn()
返回替换次数
格式:subn(pattern, repl, string, count=0, flags=0)

正则表达式对象
start()返回匹配开始的位置
end返回匹配结束的位置
span()返回一个元组包含匹配(开始,结束)的位置

简单应用

import requests
import re url='http://jandan.net/pic/MjAyMDAxMjAtMTM4#comments'
headers={} r=requests.get(url=url) imgs=re.findall('<img src="(.*?)" /></p>',r.content) print(imgs)
for img in imgs:
print(img)

参考学习:
https://www.cnblogs.com/tina-python/p/5508402.html
https://www.runoob.com/python/python-reg-expressions.html

python-网络安全编程第三天(正则表达式)的更多相关文章

  1. 【1】python核心编程 第三章

    1.继续( \ ) 有两种例外情况一个语句不使用反斜线也可以跨行.在使用闭合操作符时,单一语句可以跨多行,例如:在含有小括号.中括号.花括号时可以多行书写.另外就是三引号包括下的字符串也可以跨行书写 ...

  2. python核心编程-第三章-个人笔记

    1.语句和语法 (1)反斜杠"\"表示语句继续.python良好的编程习惯是一行最后不超过80个字符,一行字符过多时便须用到反斜杠换行继续该语句. PS:在使用小括号.中括号.大括 ...

  3. Python核心编程第三版第二章学习笔记

    第二章 网络编程 1.学习笔记 2.课后习题 答案是按照自己理解和查阅资料来的,不保证正确性.如由错误欢迎指出,谢谢 1. 套接字:A network socket is an endpoint of ...

  4. python核心编程-第三章-习题

    1.这是python的语言特性,python先创建对象,在给变量赋值时,不需要定义变量的名称和类型,它实际是用变量引用对象.变量类型在给变量赋值时自动声明 2.原因类似变量无须声明类型 3.pytho ...

  5. Python面向对象编程(三)

    封装 1.为什么要封装? 封装就是要把数据属性和方法的具体实现细节隐藏起来,只提供一个接口.封装可以不用关心对象是如何构建的 2.封装包括数据的封装和函数的封装,数据的封装是为了保护隐私,函数的封装是 ...

  6. python网络编程【三】(网络服务器)

    建立一个服务器需要以下4步: 1.建立socket对象. 2.设置socket选项(可选的) 3.绑定到一个端口(同样,也可以是一个指定的网卡). 4.侦听连接. 下面代码片段可以实现这些功能: ho ...

  7. python 网络编程(三)---TCP 服务器端客户端实现

    客户端 客户端主要有4个步骤: 1)创建一个socket以连接服务器. socket = socket.socket(family, type),family参数代表地址家族,可为AF_INET(包括 ...

  8. python 网络编程第三版

    为服务端增加多线程解决方案 1.服务端代码如下: ***这个版本并没有真正的起到多线程的作用,主要原因在于t.join():以后的版本会改进这个问题*** #!/usr/bin/python #!co ...

  9. 第十一章:Python の 网络编程基础(三)

    本課主題 多线程的创建和使用 消息队列的介绍 Python 操作 memached 和 redis 实战 本周作业 消息队列的介绍 对列是在内存中创建的,如果整个进程里的程序运行完毕之后会被清空,消息 ...

  10. 刷Python核心编程第三版的习题时遇到一个findall的坑

    在用正则表达式做以下查找时,发现re.findall()对于正则表达式有没有圆括号是有区分的,具体如下 line = 'Tue Sep 18 12:48:21 2029::ilziuv@zcntzir ...

随机推荐

  1. [转]CSS学习笔记

    原文:http://www.fx114.net/qa-266-93710.aspx 01.什么是CSS.    CSS指层叠样式表(Cascading Style Sheets).    ·样式定义如 ...

  2. win8怎样才能启用administrator登录 别的用户也是如此

    但是你可以用命令调出administrator账户打开C盘,打开windows文件夹,再打开system32文件夹,找到cmd.exe右键点击选择以管理员身份运行 在里面输入net user admi ...

  3. python web自动化上传文件工具

    工具下载地址:链接:https://pan.baidu.com/s/1cHdNHW 密码:56bp说明:1.WinSpy-1.0.2.7z解压即可.2.pywin32的exe程序,根据自己安装的pyt ...

  4. day72:drf:

    目录 1.续:反序列化功能(5-8) 1.用户post类型提交数据,反序列化功能的步骤 2.反序列化功能的局部钩子和全局钩子 局部钩子和全局钩子在序列化器中的使用 反序列化相关校验的执行顺序 3.反序 ...

  5. 学了那么多 NoSQL 数据库 NoSQL 究竟是啥

    NoSQL 简史 NoSQL 一词最早出现于 1998 年,是 Carlo Strozzi 开发的一个轻量.开源.不提供 SQL 功能的关系数据库. 2009 年,Last.fm 的 Johan Os ...

  6. CDH+Kylin三部曲之二:部署和设置

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  7. ElasticSearch实战系列九: ELK日志系统介绍和安装

    前言 本文主要介绍的是ELK日志系统入门和使用教程. ELK介绍 ELK是三个开源软件的缩写,分别表示:Elasticsearch , Logstash, Kibana , 它们都是开源软件.新增了一 ...

  8. 利用Gitee转接GitHub下载加速 简简单单 - 快快乐乐

    利用Gitee转接GitHub下载加速 简简单单 - 快快乐乐 JERRY_Z. ~ 2020 / 10 / 26 转载请注明出处!️ 目录 利用Gitee转接GitHub下载加速 简简单单 - 快快 ...

  9. 什么是SOAP?SOAP有什么用?什么时候会用到SOAP?

    什么是SOAP SOAP(Simple Object Access Protocol)一般指简单对象访问协议,简单对象访问协议是交换数据的一种协议规范,是一种轻量的.简单的.基于XML(标准通用标记语 ...

  10. 关于HDFS应知应会的N个问题 | 技术点

    1. Namenode的安全模式 ? 安全模式是Namenode的一种状态(Namenode主要有active/standby/safemode三种模式). 2. 哪些情况下,Namenode会进入安 ...