re模块操作

在Python中需要通过正则表达式对字符串进行匹配的时候,可以使用一个模块,名字为re

1. re模块的使用过程

  1. #coding=utf-8
  2. # 导入re模块
  3. import re # 使用match方法进行匹配操作
  4. result = re.match(正则表达式,要匹配的字符串) # 如果上一步匹配到数据的话,可以使用group方法来提取数据
  5. result.group()

2. re模块示例(匹配以itcast开头的语句)

  1. #coding=utf-8
  2. import re
  3. result = re.match("itcast","itcast.cn")
  4. result.group()

运行结果为:

  1. itcast

3. 说明

  • re.match() 能够匹配出以xxx开头的字符串

匹配单个字符

在上一小节中,了解到通过re模块能够完成使用正则表达式来匹配字符串

本小节,将要讲解正则表达式的单字符匹配

字符 功能
. 匹配任意1个字符(除了\n)
[ ] 匹配[ ]中列举的字符
\d 匹配数字,即0-9
\D 匹配非数字,即不是数字
\s 匹配空白,即 空格,tab键
\S 匹配非空白
\w 匹配单词字符,即a-z、A-Z、0-9、_
\W 匹配非单词字符

示例1:

  1. #coding=utf-8import re
  2. ret = re.match(".","M")
  3. print(ret.group())
  4. ret = re.match("t.o","too")
  5. print(ret.group())
  6. ret = re.match("t.o","two")
  7. print(ret.group())

运行结果:

  1. M
  2. too
  3. two

示例2:

  1. #coding=utf-8import re# 如果hello的首字符小写,那么正则表达式需要小写的hret = re.match("h","hello Python")
  2. print(ret.group())# 如果hello的首字符大写,那么正则表达式需要大写的Hret = re.match("H","Hello Python")
  3. print(ret.group())# 大小写h都可以的情况ret = re.match("[hH]","hello Python")
  4. print(ret.group())
  5. ret = re.match("[hH]","Hello Python")
  6. print(ret.group())
  7. ret = re.match("[hH]ello Python","Hello Python")
  8. print(ret.group())# 匹配09第一种写法ret = re.match("[0123456789]Hello Python","7Hello Python")
  9. print(ret.group())# 匹配09第二种写法ret = re.match("[0-9]Hello Python","7Hello Python")
  10. print(ret.group())
  11. ret = re.match("[0-35-9]Hello Python","7Hello Python")
  12. print(ret.group())# 下面这个正则不能够匹配到数字4,因此retNoneret = re.match("[0-35-9]Hello Python","4Hello Python")# print(ret.group())

运行结果:

  1. h
  2. H
  3. h
  4. H
  5. Hello Python7Hello Python7Hello Python7Hello Python

示例3:

  1. #coding=utf-8import re# 普通的匹配方式ret = re.match("嫦娥1号","嫦娥1号发射成功")
  2. print(ret.group())
  3. ret = re.match("嫦娥2号","嫦娥2号发射成功")
  4. print(ret.group())
  5. ret = re.match("嫦娥3号","嫦娥3号发射成功")
  6. print(ret.group())# 使用\d进行匹配ret = re.match("嫦娥\d号","嫦娥1号发射成功")
  7. print(ret.group())
  8. ret = re.match("嫦娥\d号","嫦娥2号发射成功")
  9. print(ret.group())
  10. ret = re.match("嫦娥\d号","嫦娥3号发射成功")
  11. print(ret.group())

运行结果:

  1. 嫦娥1
  2. 嫦娥2
  3. 嫦娥3
  4. 嫦娥1
  5. 嫦娥2
  6. 嫦娥3

说明

  • 其他的匹配符参见后面章节的讲解

匹配多个字符

匹配多个字符的相关格式

字符 功能
* 匹配前一个字符出现0次或者无限次,即可有可无
+ 匹配前一个字符出现1次或者无限次,即至少有1次
? 匹配前一个字符出现1次或者0次,即要么有1次,要么没有
{m} 匹配前一个字符出现m次
{m,n} 匹配前一个字符出现从m到n次

示例1:

需求:匹配出,一个字符串第一个字母为大小字符,后面都是小写字母并且这些小写字母可有可无

  1. #coding=utf-8import re
  2. ret = re.match("[A-Z][a-z]*","M")
  3. print(ret.group())
  4. ret = re.match("[A-Z][a-z]*","MnnM")
  5. print(ret.group())
  6. ret = re.match("[A-Z][a-z]*","Aabcdef")
  7. print(ret.group())

运行结果:

  1. M
  2. Mnn
  3. Aabcdef

示例2:

需求:匹配出,变量名是否有效

  1. #coding=utf-8import re
  2. names = ["name1", "_name", "2_name", "__name__"]for name in names:
  3. ret = re.match("[a-zA-Z_]+[\w]*",name) if ret:
  4. print("变量名 %s 符合要求" % ret.group()) else:
  5. print("变量名 %s 非法" % name)

运行结果:

  1. 变量名 name1 符合要求
  2. 变量名 _name 符合要求
  3. 变量名 2_name 非法
  4. 变量名 __name__ 符合要求

示例3:

需求:匹配出,0到99之间的数字

  1. #coding=utf-8import re
  2. ret = re.match("[1-9]?[0-9]","7")
  3. print(ret.group())
  4. ret = re.match("[1-9]?\d","33")
  5. print(ret.group())
  6. ret = re.match("[1-9]?\d","09")
  7. print(ret.group())

运行结果:

  1. 7330 # 这个结果并不是想要的,利用$才能解决

示例4:

需求:匹配出,8到20位的密码,可以是大小写英文字母、数字、下划线

  1. #coding=utf-8import re
  2. ret = re.match("[a-zA-Z0-9_]{6}","12a3g45678")
  3. print(ret.group())
  4. ret = re.match("[a-zA-Z0-9_]{8,20}","1ad12f23s34455ff66")
  5. print(ret.group())

运行结果:

  1. 12a3g41ad12f23s34455ff66

匹配开头结尾

字符 功能
^ 匹配字符串开头
$ 匹配字符串结尾

示例1:

需求:匹配163.com的邮箱地址


  1. #coding=utf-8import re
  2. email_list = ["xiaoWang@163.com", "xiaoWang@163.comheihei", ".com.xiaowang@qq.com"]for email in email_list:
  3. ret = re.match("[\w]{4,20}@163\.com", email)
  4. if ret:
  5. print("%s 是符合规定的邮件地址,匹配后的结果是:%s" % (email, ret.group()))
  6. else:
  7. print("%s 不符合要求" % email)

运行结果:


  1. xiaoWang@163.com
  2. 是符合规定的邮件地址,匹配后的结果是:
  3. xiaoWang@163.com
  4. xiaoWang@163.comheihei
  5. 是符合规定的邮件地址,匹配后的结果是:
  6. xiaoWang@163.com
  7. .com.xiaowang@qq.com 不符合要求

完善后


  1. email_list = ["xiaoWang@163.com", "xiaoWang@163.comheihei", ".com.xiaowang@qq.com"]
  2. for email in email_list:
  3. ret = re.match("[\w]{4,20}@163\.com$", email)
  4. if ret:
  5. print("%s 是符合规定的邮件地址,匹配后的结果是:%s" % (email, ret.group()))
  6. else:
  7. print("%s 不符合要求" % email)

运行结果:

  1. xiaoWang@163.com 是符合规定的邮件地址,
  2. 匹配后的结果是:xiaoWang@163.com
  3. xiaoWang@163.comheihei 不符合要求
  4. .com.xiaowang@qq.com 不符合要求

匹配分组

字符 功能
(ab) 将括号中字符作为一个分组
\num 引用分组num匹配到的字符串

示例1:

需求:匹配出0-100之间的数字


  1. #coding=utf-8
  2. import re
  3. ret = re.match("[1-9]?\d","8")
  4. print(ret.group()) # 8
  5. ret = re.match("[1-9]?\d","78")
  6. print(ret.group()) # 78
  7. # 不正确的情况
  8. ret = re.match("[1-9]?\d","08")
  9. print(ret.group()) # 0
  10. # 修正之后的
  11. ret = re.match("[1-9]?\d$","08")
  12. if ret:
  13. print(ret.group())
  14. else:
  15. print("不在0-100之间")
  16. # 添加|
  17. ret = re.match("[1-9]?\d$|100","8")
  18. print(ret.group()) # 8
  19. ret = re.match("[1-9]?\d$|100","78")
  20. print(ret.group()) # 78
  21. ret = re.match("[1-9]?\d$|100","08")
  22. # print(ret.group()) # 不是0-100之间
  23. ret = re.match("[1-9]?\d$|100","100")
  24. print(ret.group()) # 100

示例2:

需求:匹配出163、126、qq邮箱


  1. #coding=utf-8
  2. import re
  3. ret = re.match("\w{4,20}@163\.com", "test@163.com")
  4. print(ret.group()) # test@163.com
  5. ret = re.match("\w{4,20}@(163|126|qq)\.com", "test@126.com")
  6. print(ret.group()) # test@126.com
  7. ret = re.match("\w{4,20}@(163|126|qq)\.com", "test@qq.com")
  8. print(ret.group()) # test@qq.com
  9. ret = re.match("\w{4,20}@(163|126|qq)\.com", "test@gmail.com")
  10. if ret:
  11. print(ret.group())
  12. else:
  13. print("不是163、126、qq邮箱") # 不是163、126、qq邮箱

不是以4、7结尾的手机号码(11位)


  1. import re
  2. tels = ["13100001234", "18912344321", "10086", "18800007777"]for tel in tels:
  3. ret = re.match("1\d{9}[0-35-68-9]", tel)
  4. if ret:
  5. print(ret.group())
  6. else:
  7. print("%s 不是想要的手机号" % tel)

提取区号和电话号码


  1. >>> ret = re.match("([^-]*)-(\d+)","010-12345678")
  2. >>> ret.group()
  3. '010-12345678'
  4. >>> ret.group(1)
  5. '010'
  6. >>> ret.group(2)
  7. '12345678'

示例3:

需求:匹配出<html>hh</html>


  1. #coding=utf-8
  2. import re
  3. # 能够完成对正确的字符串的匹配
  4. ret = re.match("<[a-zA-Z]*>\w*</[a-zA-Z]*>", "<html>hh</html>")
  5. print(ret.group())
  6. # 如果遇到非正常的html格式字符串,匹配出错
  7. ret = re.match("<[a-zA-Z]*>\w*</[a-zA-Z]*>", "<html>hh</htmlbalabala>")
  8. print(ret.group())
  9. # 正确的理解思路:如果在第一对<>中是什么,按理说在后面的那对<>中就应该是什么
  10. # 通过引用分组中匹配到的数据即可,但是要注意是元字符串,即类似 r""这种格式
  11. ret = re.match(r"<([a-zA-Z]*)>\w*</\1>", "<html>hh</html>")
  12. print(ret.group())
  13. # 因为2对<>中的数据不一致,所以没有匹配出来
  14. test_label = "<html>hh</htmlbalabala>"
  15. ret = re.match(r"<([a-zA-Z]*)>\w*</\1>", test_label)
  16. if ret:
  17. print(ret.group())
  18. else:
  19. print("%s 这是一对不正确的标签" % test_label)

运行结果:


  1. <html>hh</html>
  2. <html>hh</htmlbalabala>
  3. <html>hh</html>
  4. <html>hh</htmlbalabala> 这是一对不正确的标签

示例4:

需求:匹配出<html><h1>www.itcast.cn</h1></html>


  1. #coding=utf-8
  2. import re
  3. labels = ["<html><h1>www.itcast.cn</h1></html>", "<html><h1>www.itcast.cn</h2></html>"]
  4. for label in labels:
  5. ret = re.match(r"<(\w*)><(\w*)>.*</\2></\1>", label)
  6. if ret:
  7. print("%s 是符合要求的标签" % ret.group())
  8. else:
  9. print("%s 不符合要求" % label)

运行结果:


  1. <html><h1>www.itcast.cn</h1></html> 是符合要求的标签
  2. <html><h1>www.itcast.cn</h2></html> 不符合要求

示例5:

需求:匹配出<html><h1>www.itcast.cn</h1></html>


  1. #coding=utf-8
  2. import re
  3. ret = re.match(r"<(?P<name1>\w*)><(?P<name2>\w*)>.*</(?P=name2)></(?P=name1)>", "<html><h1>www.itcast.cn</h1></html>")
  4. ret.group()
  5. ret = re.match(r"<(?P<name1>\w*)><(?P<name2>\w*)>.*</(?P=name2)></(?P=name1)>", "<html><h1>www.itcast.cn</h2></html>")
  6. ret.group()

注意:(?P<name>)(?P=name)中的字母p大写

运行结果:

image

原文链接:做最专业最懂你的python开发者交流平台,提供你最需要的开发学习资源。 我们专注于python开发技术的学习与交流,我们坚持,每天进步一小步,人生进步一大步!关注【Python开发者交流平台】,与我们一起学习进步。https://www.jianshu.com/u/05f416aefbe1

一起学Python:正则表达式概述的更多相关文章

  1. 第11.1节 Python正则表达式概述

    正则表达式是可匹配文本片段的模式,一个正则表达式指定了一个与之匹配的字符串集合.最简单的正则表达式为普通字符串,与它自己匹配.如正则表达式'python'与字符串'python'匹配.通过匹配,可以在 ...

  2. 小白学 Python 数据分析(15):数据可视化概述

    人生苦短,我用 Python 前文传送门: 小白学 Python 数据分析(1):数据分析基础 小白学 Python 数据分析(2):Pandas (一)概述 小白学 Python 数据分析(3):P ...

  3. 小白学 Python 数据分析(20):pyecharts 概述

    人生苦短,我用 Python 前文传送门: 小白学 Python 数据分析(1):数据分析基础 小白学 Python 数据分析(2):Pandas (一)概述 小白学 Python 数据分析(3):P ...

  4. 小白学 Python 数据分析(2):Pandas (一)概述

    人生苦短,我用 Python 前文传送门: 小白学 Python 数据分析(1):数据分析基础 概览 首先还是几个官方链接放一下: Pandas 官网:https://pandas.pydata.or ...

  5. Python正则表达式就是这么简单【新手必学】

    一前言本篇文章带大家快速入门正则表达式的使用,正则表达式的规则不仅适用python语言,基本大多数编程语言都适用,在日常使用中极为广泛,读者们有必要学好正则表达式.看完这篇文章,读者们要理解什么是正则 ...

  6. 【Python五篇慢慢弹】快速上手学python

    快速上手学python 作者:白宁超 2016年10月4日19:59:39 摘要:python语言俨然不算新技术,七八年前甚至更早已有很多人研习,只是没有现在流行罢了.之所以当下如此盛行,我想肯定是多 ...

  7. 从零开始学Python网络爬虫PDF高清完整版免费下载|百度网盘

    百度网盘:从零开始学Python网络爬虫PDF高清完整版免费下载 提取码:wy36 目录 前言第1章 Python零基础语法入门 11.1 Python与PyCharm安装 11.1.1 Python ...

  8. 第11.3节 Python正则表达式搜索支持函数search、match、fullmatch、findall、finditer

    一. 概述 re模块的函数search.match.fullmatch.findall.finditer都是用于搜索文本中是否包含指定模式的串,函数的参数都是一样的,第一个参数是模式串.第二个是搜索文 ...

  9. Python正则表达式\W+和\W*匹配过程的深入分析

    在学习re.split函数的处理过程中,发现执行如下语句及返回与老猿预想的不一致: >>> re.split('\W*','Hello,world') ['', 'H', 'e', ...

  10. Python 正则表达式入门(中级篇)

    Python 正则表达式入门(中级篇) 初级篇链接:http://www.cnblogs.com/chuxiuhong/p/5885073.html 上一篇我们说在这一篇里,我们会介绍子表达式,向前向 ...

随机推荐

  1. 看<Asp.net夜话>随笔(2013-10-13)

    1.Asp.net内置对象 1.1Request对象 封装了客户端请求信息 1.2Response对象 代表了服务器响应对象,可以向客户端返回数据 1.3Server对象 是用于获取服务器的相关信息的 ...

  2. JSP中的EL表达式详细介绍

    一.JSP EL语言定义 EL 提供了在 JSP 脚本编制元素范围外使用运行时表达式的功能.脚本编制元素是指页面中能够用于在 JSP 文件中嵌入 Java 代码的元素.它们通常用于对象操作以及执行那些 ...

  3. Mycat 读写分离+分库分表

    上次进过GTID复制的学习记录,已经搭建好了主从复制的服务器,现在利用现有的主从复制环境,加上正在研究的Mycat,实现了主流分布式数据库的测试 Mycat就不用多介绍了,可以实现很多分布式数据库的功 ...

  4. ViewPage第二课为ViewPage加入标题

    在第一课 学前准备:掌握ViewPage第一课http://blog.csdn.net/wei_chong_chong/article/details/50468832 为ViewPage加入标题: ...

  5. 宝塔 ftp 不能连接 列出时出错

    摘抄自 https://www.bt.cn/bbs/forum.php?mod=viewthread&tid=1903&page=1&extra=#pid6515 1.注意内网 ...

  6. Chrome 临时目录

    mklink /J "C:\Users\%USERNAME%\AppData\Local\Google\Chrome\User Data\Default\Cache" " ...

  7. 为何在查询中索引未被使用 (Doc ID 1549181.1)

        To Bottom * 为何在查询中索引未被使用 (Doc ID 1549181.1) To Bottom 文档内容 用途   排错步骤   高速检查   表上是否存在索引?   索引是否应该 ...

  8. 【26.34%】【codeforces 722A】Broken Clock

    time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...

  9. Linux与Windows间使用git

    Linux与Windows间使用git Linux上架设git服务器,windows可以使用git从Linux上拉取/上传数据 windows使用工具:Git for Windows Linux上的用 ...

  10. mysql分区功能(三个文件储存一张表)(分区作用)(分区方式)

    mysql分区功能(三个文件储存一张表)(分区作用)(分区方式) 一.总结 1.mysql数据表的存储方式(三个文件储存一张表): 一张表主要对应着三个文件,一个是frm存放表结构的,一个是myd存放 ...