一、正则表达式

  1. 用途

    用事先定义好的一些特定字符、及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑。
    
    ####
    简单地说
    就是用于字符串匹配的
  2. 字符组
    在同一个位置可能出现的各种字符组成的一个字符组,在正则表达式中用[]表示
    
    例子:
    规则:[] 待匹配: 匹配结果:True 规则:[-] 待匹配: 匹配结果:True 规则:[a-z] 待匹配:c 匹配结果:True 规则:[A-Z] 待匹配:! 匹配结果:False 规则:[-9A-Z] 待匹配:C 匹配结果:True
  3. 字符
    元字符    匹配内容
    . 匹配除换行符以外的任意字符
    \w 匹配字母或数字或下划线
    \s 匹配任意的空白符
    \d 匹配数字
    \n 匹配一个换行符
    \t 匹配一个制表符
    \b 匹配一个单词的结尾
    ^ 匹配字符串的开始
    $ 匹配字符串的结尾
    \W 匹配非字母或数字或下划线
    \D 匹配非数字
    \S 匹配非空白符
    a|b 匹配字符a或字符b
    () 匹配括号内的表达式,也表示一个组
    [...] 匹配字符组中的字符
    [^...] 匹配除了字符组中字符的所有字符
  4. 量词
    量词   用法说明
    * 重复零次或更多次
    + 重复一次或更多次
    ? 重复零次或一次
    {n} 重复n次
    {n,} 重复n次或更多次
    {n,m} 重复n到m次
  5. . ^ $
    正则    待匹配字符             匹配结果                  说明
    海. 海燕海娇海东 海燕海娇海东 匹配所有"海."的字符
    ^海. 海燕海娇海东 海燕 只从开头匹配"海."
    海.$ 海燕海娇海东 海东 只匹配结尾的"海.$"
  6. * + ? {}
    ?     重复一次或多次
    * 表示零次或多次
    + 表示一次或多次
    {n,m} 表示n次到m次 以上都是贪婪匹配,如果要非贪婪匹配,在后面加?
  7. 转义符
    在正则表达式中,有很多有特殊意义的是元字符,比如\n和\s等,如果要在正则中匹配正常的"\n"而不是"换行符"就需要对"\"进行转义,变成'\\'。
    
    在python中,无论是正则表达式,还是待匹配的内容,都是以字符串的形式出现的,在字符串中\也有特殊的含义,本身还需要转义。所以如果匹配一次"\n",字符串中要写成'\\n',那么正则里就要写成"\\\\n",这样就太麻烦了。这个时候我们就用到了r'\n'这个概念,此时的正则是r'\\n'就可以了。
  8. 贪婪匹配
    贪婪匹配:在满足匹配时,匹配尽可能长的字符串,默认情况下,采用贪婪匹配
    
    .*?x的用法
    取前面任意长度的字符,直到一个x出现
  9. 其他点:
    所有量词都要放在匹配规则的后面 ()分组
    需要对多个字符组进行约束量词
    如([123][abc])+ 使用|的时候,长的放前面,短的放后面 ?P<..> 给元组起名字

二、re模块

  1. findall

    #返回所有匹配的结果,放在列表中
    
    re.findall('[a-z]+', 'hsr is very cool)
  2. search
    #从前往后找,找到一个就返回
    #返回的是一个对象,通过group()才能拿到结果
    #如果没有找到对象是None,调用group会报错
    ret = re.search('h','hsr is very cool') if ret:
    print(ret.group())
  3. match
    #其他和search相同,但是必须从头就匹配得上,否则返回None
    
    ret = re.match('h','hsr is cool')
    
    if ret:
    print(ret.group())
  4. split
    # 按给定的分隔符,对字符串进行分割
    
    ret = re.split('[ab]', 'abcd')
    
    #结果:['','','cd']
    #先按a分割,再按b分割
  5. sub
    #将正则表达式匹配上的字符替换成给定的字符,替换n次
    
    ret = re.sub('regex','replace','the string',n)
  6. subn
    #与sub类似,但是会全部替换,结果返回元组(替换的结果,替换了多少次)
    
    ret = re.subn('regex','replace','the string')
  7. compile
    #如果一条正则规则式要经常使用,可以将正则表达式编译成为一个 正则表达式对象
    
    reg = re.compile('regex')
    ret = reg.search('the string')
    ret.group()
  8. finditer
    #返回一个存放结果的迭代器
    
    ret = re.finditer('regex','the string')
    for i in ret:
    pass

python 正则表达式与re模块的更多相关文章

  1. python正则表达式之re模块方法介绍

    python正则表达式之re模块其他方法 1:search(pattern,string,flags=0) 在一个字符串中查找匹配 2:findall(pattern,string,flags=0) ...

  2. Python正则表达式与re模块介绍

    Python中通过re模块实现了正则表达式的功能.re模块提供了一些根据正则表达式进行查找.替换.分隔字符串的函数.本文主要介绍正则表达式先关内容以及re模块中常用的函数和函数常用场景. 正则表达式基 ...

  3. python 正则表达式 (重点) re模块

    京东的注册页面,打开页面我们就看到这些要求输入个人信息的提示.假如我们随意的在手机号码这一栏输入一个11111111111,它会提示我们格式有误.这个功能是怎么实现的呢?假如现在你用python写一段 ...

  4. Python正则表达式与hashlib模块

    菜鸟学python第十六天 1.re模块(正则表达式) 什么是正则表达式 正则表达式是一个由特殊字符组成的序列,他能帮助对字符串的某种对应模式进行查找. 在python中,re 模块使其拥有全部的正则 ...

  5. python正则表达式与re模块-02

    正则表达式 正则表达式与python的关系 # 正则表达式不是Python独有的,它是一门独立的技术,所有的编程语言都可以使用正则 # 但要在python中使用正则表达式,就必须依赖于python内置 ...

  6. python 正则表达式re使用模块(match()、search()和compile())

    摘录 python核心编程 python的re模块允许多线程共享一个已编译的正则表达式对象,也支持命名子组.下表是常见的正则表达式属性: 函数/方法 描述 仅仅是re模块函数 compile(patt ...

  7. Python正则表达式与re模块

    在线正则表达式测试 http://tool.oschina.net/regex/ 常见匹配模式 模式 描述 \w 匹配字母数字及下划线 \W 匹配非字母数字下划线 \s 匹配任意空白字符,等价于 [\ ...

  8. Python 正则表达式、re模块

    一.正则表达式 对字符串的操作的需求几乎无处不在,比如网站注册时输入的手机号.邮箱判断是否合法.虽然可以使用python中的字符串内置函数,但是操作起来非常麻烦,代码冗余不利于重复使用. 正则表达式是 ...

  9. [ python ] 正则表达式及re模块

    正则表达式 正则表达式描述: 正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符.及这些特定字符的组合,组成一个‘规则字符串’,这个‘规则字符串’用来    表达对字符串的一种过滤 ...

随机推荐

  1. [分享]前端javascript插件(均开源)

    记录并分享一些自己使用过的插件,便于以后有相应的功能需要使用可以及时想到. 1:数字插件countUp.js 功能:用于动态显示数字的增加和减少 项目github地址:http://inorganik ...

  2. 02操控奴隶——掌握它的语言“Python”

    一 编程常识 1编程语言的发展史 程序员是计算机的主人,主人与奴隶沟通的介质是编程语言,编程语言从诞生到现在它经历了那几个阶段呢? 2 语言的特性: 3 初期的编程语言更多的是站在计算机的角度去设计编 ...

  3. Python笔记27----时间解析

    1.将时间字符串解析成真正的时间 time.strptime http://www.runoob.com/python/att-time-strptime.html 代码: import time s ...

  4. 多个 WindowsFormsHost 叠加顺序调整

    原文:多个 WindowsFormsHost 叠加顺序调整 工作中遇到多个 WindowsFormsHost 包装的控件叠加顺序的调整问题,用了 BingToFront 和 BringToBack,不 ...

  5. 关于使用动态语言运行时 (. net)

    AutoCAD Managed .NET API允许您使用使用. NET 4.0 引入的动态语言运行时 (DLR). 使用DLR可以直接访问对象, 而无需: 打开一个对象进行读取或写入, 然后在完成后 ...

  6. Jquery-操作select下拉菜单

    jQuery获取Select选择的Text和Value: 1. var checkText=jQuery("#select_id").find("option:selec ...

  7. HDU 4300 Contest 1

    扩展KMP很容易就明白过来了. 注意的是,后面明文的长度要少于密文,而且当前K+Extend[k]>=L 输出时犯了很多次二,后来人注意吧. #include <cstdio> #i ...

  8. H2数据库入门使用

    H2数据库入门使用 学习了: https://www.cnblogs.com/xdp-gacl/p/4171024.html http://www.cnblogs.com/xdp-gacl/p/417 ...

  9. cloudstack给已有zone加入物理网络

    默认情况下,假设zone建立完后.cloudstack是不提供加入物理网络接口的. 基础架构- 域 - 物理网络 以下仅仅有我们创建zone的时候加入的物理网络 假设想在这个基础上加入一个物理网络是没 ...

  10. MapReduce(十六): 写数据到HDFS的源代码分析

    1)   LineRecordWriter负责把Key,Value的形式把数据写入到DFSOutputStream watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZ ...