正则表达式

1. 正则表达式

re模块:re模块本身只是用来操作正则表达式的,和正则本身没关系。

正则表达式:是一种规则 匹配字符串的规则。

为什么要有正则表达式?

  • 1.匹配字符串

    - 一个人的电话号码
    - 一个人的身份证号
    - 一台机器的ip地址
  • 2.表单验证

    - 验证用户输入的信息是否准确
    11位 全数字 1开头 第二个数3-9之内的数
    - 银行卡号
  • 3.爬虫

    从网页源码中获取一些链接、重要数据

正则规则(元字符,量词):

第一条规则 : 本身是哪一个字符,就匹配字符串中的哪一个字符。

第二条规则 : 字符组[字符1字符2],一个字符组就代表匹配一个字符,只要这个字符出现在字符组里,那么就说明这个字

​ 符能匹配上

  • 字符组中还可以使用范围

    所有的范围都必须遵循ascii码从下到大来指定。如:[0-9] [a-z] [A-Z]

2. 元字符

    1. \d(digit) \w(word) \s(space) \t(table) \n(next)

      [0-9] \d 表示所有的数字

      • d --> d
      • \d --> \是转义符,转义符转义了d,让d能够匹配所有0-9之间的数
      • [\d] [0-9] \d 没有区别 都是要匹配一位数字

      \w 表示 大小写字母、数字、下划线

      \s 表示空白、空格、换行符、制表符

      \t 匹配制表符

      \n 匹配换行符

    2. \D \W \S

      \D 表示所有的非数字

      \W 表示除数字、字母、下划线之外的所有字符

      \S 表示非空白

      [\d\D] [\W\w] [\S\s] 匹配所有一切字符

    3. . 表示除了换行符之外的任意内容

      \ . 在.前加一个 转义符。表示取消.的意义。

    4. [] [^]

      [] 字符组 :只要在中括号内的所有字符都是符合规则的字符

      [^ ]非字符组 :只要在中括号内的所有字符都是不符合规则的字符

    5. ^ $

      ^ 表示一个字符的开始

      ^a
      abc abc abc # 表示要匹配开始的a

      $ 表示一个字符的结束

      c$
      abc abc abc # 表示要匹配结束的c

      ^ $ 两个同时存在时,他俩之间的正则规定长度必须和要匹配的内容长度一致。

    6. | ()

      | 表示或,注意:如果两个规则有重叠部分,总是长的在前面,短的在后面

      () 表示分组,给一部分正则规定为一组,| 这个符号的作用域就可以缩小了

3. 量词

{n} 表示只能出现n次

{n,m}表示至少出现n次,至多出现m次

? 表示匹配0次或1次 表示可有可无 但是有只能有一个 比如小数点

. 表示匹配1次或多次

*表示匹配0次或多次 表示可有可无 但是有可以有多个 比如小数点后n位

什么时候会用到匹配0次?

1.匹配任意的2位整数   \d{2}
2.匹配任意的保留两位小数的数字 \d\.\d{2}
3.匹配一个整数或者小数 \d+\.\d+|\d+ \d+\.?\d* \d+(\.\d+)?

4. 贪婪匹配

正则表达式默认贪婪匹配,总是会在符合量词条件的范围内尽量多匹配。

正则表达式遵循了回溯算法,回溯算法导致了贪婪匹配。

\d{7,12}

adljdkjsljdlj

非贪婪匹配 (惰性匹配):总是匹配符合条件范围内尽量小的字符串。

元字符 量词 ,在量词后面加一个?,表示去最少的匹配

元字符 量词 ? x :表示按照元字符规则在量词范围内匹配,一旦遇到x就停止

.*?x 匹配任意的内容任意多次遇到x就立即停止

(\d+?x .*?x )非贪婪匹配在爬虫中会常用

# 身份证号
# 15位 全数字 首位不为0
# 18位 前17位全数字 首位不为0 最后一位可能是x和数字
[1-9](\d{16}(\d|x)|\d{14})
[1-9](\d{16}[\dx]|\d{14})
[1-9]\d{14}(\d{2}[\dx])?

python day25 正则表达式的更多相关文章

  1. [python] 常用正则表达式爬取网页信息及分析HTML标签总结【转】

    [python] 常用正则表达式爬取网页信息及分析HTML标签总结 转http://blog.csdn.net/Eastmount/article/details/51082253 标签: pytho ...

  2. Python 进阶 - 正则表达式

    1. 正则表达式基础 1.1. 简单介绍 正则表达式并不是Python的一部分.正则表达式是用于处理字符串的强大工具,拥有自己独特的语法以及一个独立的处理引擎,效率上可能不如str自带的方法,但功能十 ...

  3. python study - 正则表达式

    第 7 章 正则表达式 7.1. 概览 7.2. 个案研究:街道地址 7.3. 个案研究:罗马字母 7.3.1. 校验千位数 7.3.2. 校验百位数 7.4. 使用 {n,m} 语法 7.4.1. ...

  4. python使用正则表达式文本替换

    2D客户端编程从某种意义上来讲就是素材组织,所以,图片素材组织经常需要批量处理,python一定是最佳选择,不管是win/linux/mac都有一个简单的运行环境 举两个应用场景: 如果不是在某个文件 ...

  5. python的正则表达式 re

    python的正则表达式 re 本模块提供了和Perl里的正则表达式类似的功能,不关是正则表达式本身还是被搜索的字符串,都可以是Unicode字符,这点不用担心,python会处理地和Ascii字符一 ...

  6. Python之正则表达式(re模块)

    本节内容 re模块介绍 使用re模块的步骤 re模块简单应用示例 关于匹配对象的说明 说说正则表达式字符串前的r前缀 re模块综合应用实例 正则表达式(Regluar Expressions)又称规则 ...

  7. Python:正则表达式详解

    正则表达式是一个很强大的字符串处理工具,几乎任何关于字符串的操作都可以使用正则表达式来完成,作为一个爬虫工作者,每天和字符串打交道,正则表达式更是不可或缺的技能,正则表达式的在不同的语言中使用方式可能 ...

  8. 【Python】正则表达式纯代码极简教程

    <Python3正则表达式>文字版详细教程链接:https://www.cnblogs.com/leejack/p/9189796.html ''' 内容:Python3正则表达式 日期: ...

  9. 【Python】正则表达式简单教程

    说明:本文主要是根据廖雪峰网站的正则表达式教程学习,并根据需要做了少许修改,此处记录下来以备后续查看. <Python正则表达式纯代码极简教程>链接:https://www.cnblogs ...

随机推荐

  1. jython研究笔记

    jython目前只支持python2,不支持python3. python中使用第三方包的话需要重新设置lib的地址. public void getHtmlByTxt(String path) { ...

  2. 1021 docker prometheus监控体系

    jmeter plugin监控的信息很少,只有cpu.内存.网络IO,但这些是不够的.例如对于分析mysql数据库的慢查询.最大连接数等更加细密度的信息. 服务端稳定测试的三个前提: 1.应用级别的自 ...

  3. 39. Combination Sum + 40. Combination Sum II + 216. Combination Sum III + 377. Combination Sum IV

    ▶ 给定一个数组 和一个目标值.从该数组中选出若干项(项数不定),使他们的和等于目标值. ▶ 36. 数组元素无重复 ● 代码,初版,19 ms .从底向上的动态规划,但是转移方程比较智障(将待求数分 ...

  4. Python中的strip()函数的用法

    函数:string.strip() Python strip() 方法用于移除字符串头尾指定的字符(默认为空格). 一.函数说明 strip() 语法:str.strip([rm]); 参数说明 rm ...

  5. RAD XE8

    http://community.embarcadero.com/index.php/blogs/entry/rad-studio-2015-roadmap http://www.embarcader ...

  6. AnyConnect removes "Connections" tab from IE Settings solution

    I have an ASA 5510 that we use for SSL VPN Client access.  The ASA distributes the AnyConnect (v2.4. ...

  7. ATL控件签名之后页面还提示“在此页面上的Activex控件和本页上的其他部分及交互可能不安全”

    ATL控件正常签名打包,然后安装之后还是会提示: 没理由啊,签名是花钱搞得正当的签名.后来查了资料才知道这还不够,需要在创建ATL控件的时候继承一个IObjectSafetyImpl 类 知道了原因, ...

  8. sqlserver数据库导出成insert语句

    点击数据库名称右键=========>任务========>生成脚本 一.表结构导出成sql语句 二.数据导出成sql语句

  9. netbeans php环境搭建

    jdk必须: sudo apt-get install openjdk-7-jdk

  10. 分享 - 普通程序员如何转向AI方向

    原作者:计算机的潜意识 原文链接,内容稍有改动,侵删 1. 目的2. AI领域简介3. 学习方法4. 学习路线 0) 领域了解1) 知识准备2) 机器学习3) 实践做项目4) 深度学习5) 继续机器学 ...