正则表达式是一种小型的,高度专业化的变成语言,在 Python 中,它通过 re 模块实现。正则表达式模式被编译成一系列的字节码,然后由用 C 编写的引擎执行。

findall() 方法,所有匹配的结果都返回到一个列表里

import re

res = re.findall('klvchen', 'hello ,My name is klvchen. Are you ok?')
print(res)
运行结果:
['klvchen']

原字符: . ^ $ * + ? { } [ ] | ( ) \

. 只能代指任意一个字符

import re

res = re.findall('w..l', 'hello world')
print(res)
运行结果:
['worl'] res = re.findall('w..l', 'hello w\t ld')
print(res)
运行结果:
['w\t l'] # \t 空格也是属于一个字符

^ 以后面一个字符开头

import re

res = re.findall('^h...o ', 'hello world')
print(res)
运行结果:
['hello']

$ 以前面一个字符结尾

import re

res = re.findall('wo..d$', 'hello,world')
print(res)
运行结果:
['world']

* 重复匹配前面一个字符 (0个或多个), 默认是贪婪匹配

import re

res = re.findall('ba*', 'urtslkfslabaaaa')
print(res)
运行结果:
['baaaa'] res = re.findall('ba*?', 'urtslkfslabaaaa') # 后面加 ? 号使其变成惰性匹配
print(res)
运行结果:
['b']

+ 重复匹配前面一个字符(1个或多个), 默认是贪婪匹配

import re

res = re.findall('a+b', 'urtslkfslabaaaa')
print(res)
运行结果:
['ab']

? 重复匹配前面一个字符(0个或1个)

import re

res = re.findall('a?b', 'urtblkfslabaaaa')
print(res)
运行结果:
['b', 'ab']

{n, m} 匹配 n 到 m 次由前面的正则表达式定义的片段,贪婪方式

import re

res = re.findall('a{3}', 'aaab')
print(res)
运行结果:
['aaa'] res = re.findall('a{1,2}', 'aaab')
print(res)
运行结果:
['aa', 'a']

[] 用来表示一组字符,单独列出:[amk] 匹配 'a','m'或'k', 取消元字符的特殊功能

import re

res = re.findall('a[b,c]d', 'acd')
print(res)
运行结果:
['acd'] res = re.findall('[a-zA-Z]', 'acd')
print(res)
运行结果:
['a', 'c', 'd'] res = re.findall('[w,*]', 'klwdx*')
print(res)
运行结果:
['w', '*'] res = re.findall('[w,,]', 'klwdx*,')
print(res)
运行结果:
['w', ','] res = re.findall('[1-9]', 'hsdl1dsfsf56')
print(res)
运行结果:
['1', '5', '6'] res = re.findall('[1-9,a-z,A-Z]','12klvCHEN')
print(res)
运行结果:
['1', '2', 'k', 'l', 'v', 'C', 'H', 'E', 'N']

^ 在 [] 里,取反

import re

res = re.findall('[^1,2]','h1w 2')
print(res)
运行结果:
['h', 'w', ' ']

() 代表着一个整体

import re

res = re.findall('www.(\w+).com','www.baidu.com')   #返回()的内容
print(res)
运行结果:
['baidu'] res = re.findall('www.(?:\w+).com','www.baidu.com') #返回整体
print(res)
运行结果:
['www.baidu.com']
模式 说明
\d 匹配任何十进制数,相当于 [0-9]
\D 匹配任何非十进制数,相当于 [ ^0-9 ]
\s 匹配任何空白字符,相当于 [ \t\n\r\f\v]
\S 匹配任何非空白字符,相当于 [ ^\t\n\r\f\v ]
\w 匹配任何字母数字字符,相当于 [a-zA-Z0-9]
\W 匹配任何非字母数字字符,相当于 [ ^a-zA-Z0-9 ]
\b 匹配一个单词边界,也就是指单词和空格间的位置。例如, 'er\b' 可以匹配"never" 中的 'er',但不能匹配 "verb" 中的 'er'。
import re

res = re.findall('\d{11}', 'abcd123456789098765')
print(res)
运行结果:
['12345678909'] res = re.findall('\sabc', 'hello abc')
print(res)
运行结果:
[' abc'] res = re.findall('\w', 'he llo')
print(res)
运行结果:
['h', 'e', 'l', 'l', 'o'] res = re.findall(r'I\b', 'hello,I am klvchen')
print(res)
运行结果:
['I'] res = re.findall(r'\\','ab\cde')
print(res)
运行结果:
['\\']

search 方法,返回匹配到的第一个对象(object), 需要调用group()返回结果

import re

res = re.search('kl', 'hello, my name is klvchen')
print(res)
print(res.group())
运行结果:
<_sre.SRE_Match object; span=(18, 20), match='kl'>
kl res = re.search('a\.', 'a.jpg').group()
print(res)
运行结果:
a. res = re.search('(as)+','sdfsafasksas').group()
print(res)
运行结果:
as res = re.search('(as)|3','abas8as').group()
print(res)
运行结果:
as res = re.search('(?P<id>\d{4})','hello,12345678') #(?P<名字>正则)这是固定格式,然后可以通过名字调用
print(res.group('id'))
运行结果:
1234 res = re.search('(?P<id>\d{4})/(?P<name>\w{2})','hello,12345678/klvchen')
print(res.group('id'))
print(res.group('name'))
运行结果:
5678
kl

match() 方法,仅在字符串开始的地方匹配,返回匹配到的第一个对象(object), 需要调用group()返回结果

import re

res = re.match('abc','aabcdabc')
print(res)
运行结果:
None res = re.match('abc','abcdabc')
print(res.group())
运行结果:
abc

split() 方法

import re
res = re.split('[b,f]','abcdefghij') # 先切割 b ,再对剩下的字符串以 f 进行切割
print(res)
运行结果:
['a', 'cde', 'ghij']

sub() 方法

import re
res = re.sub('k.v','abc','klvchen')
print(res)
运行结果:
abcchen res = re.sub('\d','8','k1v2chen',1) # 只替换一次
print(res)
运行结果:
k8v2chen

compile() 方法

obj = re.compile('\.com')
res = obj.findall('ab.comdefg')
print(res)
运行结果:
['.com']

finditer() 方法

res = re.finditer('\d', 'ab3cd4gh5jk')
print(res)
print(next(res).group())
print(next(res).group())
运行结果:
<callable_iterator object at 0x0000013DFF84CD30>
3
4

Python 正则介绍的更多相关文章

  1. Python正则式的基本用法

    Python正则式的基本用法 1.1基本规则 1.2重复 1.2.1最小匹配与精确匹配 1.3前向界定与后向界定 1.4组的基本知识 2.re模块的基本函数 2.1使用compile加速 2.2 ma ...

  2. python 正则,常用正则表达式大全

    Nginx访问日志匹配 re.compile #re.compile 规则解释,改规则必须从前面开始匹配一个一个写到后面,前面一个修改后面全部错误.特殊标准结束为符号为空或者双引号:  改符号开始 从 ...

  3. 从零开始学Python第0周:Python基本介绍(部分内容来源于网络)

    Python入门介绍 一,Python的基本介绍 (1)概要 Python是一种解释型,面向对象,动态数据类型的高级程序设计语言.常被广泛用于处理系统管理任务和web编程.现如今Python已经成为了 ...

  4. python 正则使用笔记

    python正则使用笔记 def remove_br(content): """去除两边换行符""" content = content.r ...

  5. Python正则处理多行日志一例

    正则表达式基础知识请参阅<正则表达式基础知识>,本文使用正则表达式来匹配多行日志并从中解析出相应的信息. 假设现在有这样的SQL日志: SELECT * FROM open_app WHE ...

  6. 【转】Python Twisted介绍

    Python Twisted介绍 作者:Jessica McKellar 原文链接 Twisted是用Python实现的基于事件驱动的网络引擎框架.Twisted诞生于2000年初,在当时的网络游戏开 ...

  7. 【美妙的Python之中的一个】Python简单介绍及环境搭建

    美妙的Python之Python简单介绍及安装         简而言之: Python 是能你无限惊喜的语言,与众不同.             1.Python:                  ...

  8. Python正则匹配字母大小写不敏感在读xml中的应用

    需要解决的问题:要匹配字符串,字符串中字母的大小写不确定,如何匹配? 问题出现之前是使用字符串比较的方式,比如要匹配'abc',则用语句: if s == 'abc':#s为需要匹配的字符串 prin ...

  9. python模块介绍- multi-mechanize 性能测试工具

    python模块介绍- multi-mechanize 性能测试工具 2013-09-13 磁针石 #承接软件自动化实施与培训等gtalk:ouyangchongwu#gmail.comqq 3739 ...

随机推荐

  1. UniGUI的布局使用说明

    (unigui的页面布局还是很强大的,基本什么的排版都能搞好.前面部分为原文章翻译,翻译不一定很准确,就能看吧,后面有使用说明,有什么不明白的欢迎加我QQ(910300653)一起交流学习) 一.布局 ...

  2. UIAlertControllerStyleActionSheet 崩溃。

    即使Devices 设置为iPhone模式,在审核时还是运行在iPad的小屏模式下.因此必须 UIActivityViewController UIAlertControllerStyleAction ...

  3. 一篇入门 -- Scala

    整体介绍 Scala 是一门多范式(multi-paradigm)的编程语言,设计初衷是要集成面向对象编程和函数式编程的各种特性. 联邦理工学院洛桑(EPFL)的Martin Odersky于2001 ...

  4. 【安全狗SRC】抗D设备哪家强?你来!大佬告诉你答案

    上周,安全狗SRC联合SRC部落,携手推出了爆款话题:传统抗D设备 vs 新兴CDN抗D:抗D效果哪个好? 一经发布简直好评如潮,热评无数,四方雷动(?)原帖在此,错过的吃瓜表哥们可以再围观一下~ht ...

  5. Android之ListView,AsyncTask,GridView,CardView,本地数据存储,SQLite数据库

    版权声明:未经博主允许不得转载 补充 补充上一节,使用ListView是用来显示列表项的,使用ListView需要两个xml文件,一个是列表布局,一个是单个列表项的布局.如我们要在要显示系统所有app ...

  6. windows快速打开命令窗口方式[利刃篇]

    windows当然是窗口界面操作了,谁有事没事去用什么命令行啊,但是当你要用的时候,也要会用才行哦. 打开命令行的方式小说一下: 1.开始 > 运行 > cmd , enter,  ok ...

  7. Scala + IntelliJ IDEA

    学习路上的新起点:大数据Scala + Spark +(HDFS + HBase),本文主要介绍下Scala的基本语法和用法吧.最后再简单介绍一种Java开发工具IntelliJ IDEA的使用. S ...

  8. LeetCode--No.012 Integer to Roman

    12. Integer to Roman Total Accepted: 71315 Total Submissions: 176625 Difficulty: Medium Given an int ...

  9. iOS-关于缓存【SDImageCache】Image,一直刷新UIImageView内存一直增加问题

    最近做的一个项目,里面有这样一个需求,在一个页面,用一个UIImageView不停的刷新显示图片,图片可能会重复显示:图片是从服务器下载下来的data流,data转UIimage系统的方法: UIIm ...

  10. linux系统添加swap(虚拟内存)分区

    ​ 在实际的生产环境中,实际的物理内存我们经常会觉得不够用,增加物理内存的成本又比较高,一种折中方案就出来了,使用硬盘的一部分空间来做Swap(windows 下叫虚拟内存),将系统内非活动内存换页到 ...