1.“字符*” 匹配*前面的字符0次或者多次

注意:是匹配*前一个字符,只能是*前一个字符多次打印出来。*前面其他的字符相当于前缀会打印出来,但是不会再匹配。

*前一个字符前面的其他字符里的首字符先遇到会直接停下来,不去寻找其他的字符。

print(re.search("rt*","rrtbbbbrbrbreyrtrr"))
# <_sre.SRE_Match object; span=(0, 1), match='r'>  
print(re.findall("r*","tyrrreyrtrr"))
print(re.search("r*","ureyrtrr")) # ['', '', 'rrr', '', '', 'r', '', 'rr', '']
# <_sre.SRE_Match object; span=(0, 0), match=''>
print(re.search("r*","rrrreyrtrr"))

# <_sre.SRE_Match object; span=(0, 4), match='rrrr'>

2.“+”  匹配一个或多个字符。

print(re.search(".+","rbbbbrbrbreyrtrr"))        #可以利用·+输出所有字符
print(re.search(".","rbbbbrbrbreyrtrr"))
print(re.search("b+","rbbbbrbrbreyrtrr"))
print(re.search("ab+","rbbabbrbrbreyrtrr")) # <_sre.SRE_Match object; span=(0, 16), match='rbbbbrbrbreyrtrr'>
# <_sre.SRE_Match object; span=(0, 1), match='r'>
# <_sre.SRE_Match object; span=(1, 5), match='bbbb'>
# <_sre.SRE_Match object; span=(3, 6), match='abb'>

当 +前面有多个字符时和 *区别,如下

print(re.search("ab+","rbbaaaabbrbrbreyrtrr"))    #一直找到ab
print(re.search("ab*","rbbaaaabbrbrbreyrtrr"))    #遇a即停 # <_sre.SRE_Match object; span=(6, 9), match='abb'>
# <_sre.SRE_Match object; span=(3, 4), match='a'>

3.“?”  匹配一次或0次

print(re.search("ab?","abbbaaaabbrbrbreyrtrr"))
# <_sre.SRE_Match object; span=(0, 2), match='ab'>

4.“字符{m}”  匹配前面的字符m次

print(re.search("[a-z]{2}","abbbaaaabbrbrbreyrtrr"))
# <_sre.SRE_Match object; span=(0, 2), match='ab'>

5.“{n-m}”  匹配前面的字符n-m次

print(re.search("[a-b]{2,5}","tabbvbtaaaabbrbrbreyrtrr"))
# <_sre.SRE_Match object; span=(1, 4), match='abb'>

6.“|”  或,满足其中一个即可匹配。

print(re.search("[a|A]lex","alex"))
print(re.search("[a|A]lex","Alex")) # <_sre.SRE_Match object; span=(0, 4), match='alex'>
# <_sre.SRE_Match object; span=(0, 4), match='Alex'>
print(re.search("[a|A]{2}","aalaex"))   #输出aa

  

  

  

  

  

re正则表达式2的更多相关文章

  1. JS正则表达式常用总结

    正则表达式的创建 JS正则表达式的创建有两种方式: new RegExp() 和 直接字面量. //使用RegExp对象创建 var regObj = new RegExp("(^\\s+) ...

  2. Python高手之路【五】python基础之正则表达式

    下图列出了Python支持的正则表达式元字符和语法: 字符点:匹配任意一个字符 import re st = 'python' result = re.findall('p.t',st) print( ...

  3. C# 正则表达式大全

    文章导读 正则表达式的本质是使用一系列特殊字符模式,来表示某一类字符串.正则表达式无疑是处理文本最有力的工具,而.NET提供的Regex类实现了验证正则表达式的方法.Regex 类表示不可变(只读)的 ...

  4. C#基础篇 - 正则表达式入门

    1.基本概念 正则表达式(Regular Expression)就是用事先定义好的一些特定字符(元字符)或普通字符.及这些字符的组合,组成一个“规则字符串”,这个“规则字符串”用来判断我们给定的字符串 ...

  5. JavaScript正则表达式,你真的知道?

    一.前言 粗浅的编写正则表达式,是造成性能瓶颈的主要原因.如下: var reg1 = /(A+A+)+B/; var reg2 = /AA+B/; 上述两个正则表达式,匹配效果是一样的,但是,效率就 ...

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

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

  7. 【JS基础】正则表达式

    正则表达式的() [] {}有不同的意思. () 是为了提取匹配的字符串.表达式中有几个()就有几个相应的匹配字符串. (\s*)表示连续空格的字符串. []是定义匹配的字符范围.比如 [a-zA-Z ...

  8. JavaScript 正则表达式语法

    定义 JavaScript定义正则表达式有两种方法. 1.RegExp构造函数 var pattern = new RegExp("[bc]at","i"); ...

  9. [jquery]jquery正则表达式验证(手机号、身份证号、中文名称)

    数字判断方法:isNaN()函数 test()方法 判断字符串中是否匹配到正则表达式内容,返回的是boolean值 ( true / false ) // 验证中文名称 function isChin ...

  10. JS中给正则表达式加变量

    前不久同事询问我js里面怎么给正则中添加变量的问题,遂写篇博客记录下.   一.字面量 其实当我们定义一个字符串,一个数组,一个对象等等的时候,我们习惯用字面量来定义,例如: var s = &quo ...

随机推荐

  1. POJ 2421 Constructing Roads (Kruskal算法+压缩路径并查集 )

    Constructing Roads Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 19884   Accepted: 83 ...

  2. POJ3259 Wormholes —— spfa求负环

    题目链接:http://poj.org/problem?id=3259 Wormholes Time Limit: 2000MS   Memory Limit: 65536K Total Submis ...

  3. PLSQL 安装说明

    PLSQL安装说明. 1.安装oracle 11g ,2030端口设置防火墙例外.2.PLSQL Developer 9.0.0.1601是绿色版,复制到本地即可.3.PLSQL->Tools- ...

  4. Bug不能重现的原因分析及其对策

    摘 要:本文简要分析了无法重现的Bug的可能产生原因,包括环境不一致.缺少最准确的描述和浏览器的不当设置.针对这些原因,本文给出了相应的对策.通过这些措施,可以重现许多以前认为不可重现的Bug.    ...

  5. JRE System Library 与Java EE Libraries的区别

    JRE System Library是只要做java开发都需要的完整的.标准的库.  Java EE5 Libraries只是java三个方向中做java EE所需要的库.如果做Web方面的开发的话就 ...

  6. Perl解析JSON数据精解

    简介:JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于JavaScript(Standard ECMA-262 3rd Edition - Dece ...

  7. BZOJ1453: [WC2005]Dface双面棋盘

    离线LCT维护MST,和3082的方法一样.然而比较码农,适合颓废的时候写. PS:线段树分治要好写得多,LCT比较自娱自乐. #include<bits/stdc++.h> using ...

  8. Luogu网校听课笔记(自用

    TG助学课——noilinux 8.2 深夜 Noi Linux的使用——darkflames的博客 #include<bits/stdc++.h> using namespace std ...

  9. 【HDU 4722】 Good Numbers

    [题目链接] 点击打开链接 [算法] f[i][j]表示第i位,数位和对10取模余j的数的个数 状态转移,计算答案都比较简单,笔者不再赘述 [代码] #include<bits/stdc++.h ...

  10. JAVA 布局控制

    在Java里该方法是安一个组件到一个窗体中去,它不同我们使用过的其它GUI系统.首先,它是全代码的:没有控制安放组件的“资源”.其次,该方法的组件被安放到一个被“布局管理器”控制的窗体中,由“布局管理 ...