模块:

  • 模块就是一组功能的集合,你要和某个东西打交道,而这个东西本身和Python没有关系,这个东西本身就存在,Python提供了一个功能的集合,专门负责和这个东西打交道.
  • 模块的类型:
    • 内置模块 不需要我们自己安装的 解释器自带的
    • 第三方模块 需要我们自己安装的模块
    • 自定义模块 我们自己写的模块
  • re模块:
    • 在Python中使用正则表达式

      • 正则表达式:

        • 是一种独立的规则,独立的语言,只和字符串打交道
        • 功能:
          • 从大段的文字中找到符合规则的内容

            • 比如说爬虫,从网页的字符串中获取你想要的数据
            • 日志分析.提取日志中你想要获取的数据
          • 判断某个字符串是否完全符合规则
            • 表单验证:手机号,qq号.邮箱,银行卡,身份证号.密码
        • 规则:
          • 规则 字符串 从字符串中找到符合规则的内容
        • 字符组[ ]写在括号中的内容,都出现在下面的某一个字符的位置上且都是符合规则的
          • [0-9]匹配数字
          • [a-z]匹配小写字母
          • [A-Z]匹配大写字母
          • [a-zA-Z]匹配大小写字母
          • [a-zA-Z0-9]匹配大小写字母+数字
          • [a-zA-Z0-9_]匹配数字字母下滑线
        • 元字符
          • 贪婪匹配/惰性匹配:默认贪婪/量词?惰性匹配
          • 和转义字母相关的元字符
            • \w匹配数字字母下滑线 关键字(word) 如[a-zA-Z0-9_]
            • \d匹配所有数字 关键字(digit) 如[0-9]
            • \s匹配所有的空白符 \n回车(换行符),\t制表符(Tab),空格
            • \W,\D,\S是上面三个元字符的反义
              • [\s\S][\d\D][\w\W]是三组全集 意思是匹配所有字符
            • \b表示单词的边界
          • ^和$
            • ^是匹配一个字符串的开始
            • $是匹配一个字符串的结束
          • . 表示匹配除了换行符之外的所有字符
          • [ ]只要出现在中括号内的内容都可以被匹配
          • [^]只要不出现在中括号中的内容都可以被匹配(有一些有特殊意义的元字符进入字符组中会恢复它本来的意义: . | [ ] ( ) )
          • a|b 或 符合a规则的或者b规则的都可以被匹配
          • 如果a规则是b规则的一部分,且a规则比b规则要苛刻/长,就把a规则写在前面(将更复杂的\更长的规则写在最前面)
          • ( ) 分组 表示给几个字符加上量词约束的需求的时候,就给这些量词分在一个组
        • 量词:
          • {n}表示这个量词之前的字符出现n次
          • {n,}表示这个量词之前的字符至少出现n次
          • {n,m}表示这个量词之前的字符出现n-m次
          • ? 表示匹配量词之前的字符出现0次或者1次 表示可有可无
          • + 表示匹配量词之前的字符出现1次或者多次
          • * 表示匹配量词之前的字符出现0次或者多次

Python_Mix*re模块,元字符,量词的更多相关文章

  1. re模块元字符

    #元字符在re模块中有特殊意义的字符,有:^ $. * + {} [] () | \ ^$ #表示开头结尾,注意:[^]表示取反 . #点,表示任意一个字符,包括空格(一个空白字符),\t(换行符). ...

  2. Python_Mix*OS模块,序列化模块种的json,pickle

    os.path.basename(path)返回path最后的文件名,如何path以/或\结尾,那么就会返回空值,即os.path.split(path)的第一个元素 ret = os.path.ba ...

  3. Python_Mix*random模块,time模块,sys模块,os模块

    random模块 作用: 生成随机数(整数,小数,从列表中随机抽值,打乱列表顺序) 常用函数: random.random( )生成随机小数 random.uniform( )取一个范围之间的小数 r ...

  4. Python_Mix*re模块基础方法,进阶,正则表达式的使用

    re模块import re 基础方法 findall:匹配所有 ,每一项都是列表中的一个元素,返回的是列表 search只匹配从左到右的第一个,得到的不是直接的结果,而是一个变量,通过这个变量的gro ...

  5. <摘录>perl正则表达式中的元字符、转义字符、量词及匹配方式

    Linux平台上被广泛使用的正则表达式库PCRE - Perl-compatible regular expressions,从其名字即可知道,PCRE提供的是一套与Perl中相兼容的正则表达式. 元 ...

  6. 【Perl】perl正则表达式中的元字符、转义字符、量词及匹配方式

    Linux平台上被广泛使用的正则表达式库PCRE - Perl-compatible regular expressions,从其名字即可知道,PCRE提供的是一套与Perl中相兼容的正则表达式. 元 ...

  7. python之正则表达式和re模块一

    摘要:正则表达式 re模块 一.正则表达式:只和字符串打交道,是一种用来约束字符串的规则 1.应用场景: 1,判断某一个字符串是否符合规则:注册页-判断手机号.身份证号 是否合法 注册某个账号的时候, ...

  8. 基础的正则表达式与re模块(2)

    一.元字符 字符组是元字符中的一个.在字符组中所有的字符都可以匹配任意一个字符位置上能出现的内容,如果在字符串中有任意一个字符是字符组中的内容,那么就是匹配上的项. [0-9]   [a-z]    ...

  9. 分分钟钟学会Python - 模块

    目录 模块 1 模块基础知识 2 random 返回随机生成的一个实数 3 hashlib 摘要算法模块 Hmac算法 4 time /datetime 时间模块 5 getpass 密码不显示(只能 ...

随机推荐

  1. 【Diary】

    [写日记是好习惯] 前记 很随意的日记.想什么写什么,没有限制. 希望以后看到曾经,努力的自己比摸鱼的自己多. 2019.3 2019.3.29 第24次请假打卡 xzh:那些理科男以后都会当IT工作 ...

  2. Maven pom.xml文件详解

    Maven pom.xml文件详解 一.简介 POM全称是Project Object Model,即项目对象模型. pom.xml是maven的项目描述文件,它类似与antx的project.xml ...

  3. css浮动与清除浮动

    css浮动 首先,我们要知道,css中块级元素在页面中是独占一行的,自上而下排列,也就是我们所说的流,通常称为标准流. 以div为例,div是块级元素,如下: 可以清楚地看到,div是独占一行的,di ...

  4. H5外包团队 技术分享 基于H5+的项目分享

    项目截图:             有H5项目需求欢迎联系我们 我们提供免费的项目评估报价 QQ:372900288 WX:Liuxiang0884

  5. leecode第二百一十七题(存在重复元素)

    class Solution { public: bool containsDuplicate(vector<int>& nums) { set<int> s; for ...

  6. Centos7 防火墙frewalld规则设置

    配置firewalld-cmd 查看版本: firewall-cmd --version 查看帮助: firewall-cmd --help 显示状态: firewall-cmd --state 查看 ...

  7. C# WPF开发之MVVM模式开发

    MVVM模式由Model,View,ViewModel三部分组成. Model需继承INotifyPropertyChange(属性修改通知) ViewModel负责业务逻辑,连接View和Model ...

  8. 非阻塞模式(ioctlsocket)

    //Server.cpp #include <stdio.h> #include <winsock2.h> //winsock.h (2种套接字版本) #pragma comm ...

  9. vue 移动端轻量日期组件不依赖第三方库

    Vue版移动端日期选择组件 1.优点:不需要依赖其他第三方库,灵活可配置: 不需要依赖第三方组件的vue日期移动端组件  小轮子 轻量可复用:  https://github.com/BeckReed ...

  10. idea 本地tomcat启动控制台乱码问题

    问题:本地tomcat启动,控制台出现中文乱码: 解决办法: 安装了idea发现启动tomcat的时候控制台会有乱码问题,在tomcat配置中添加在VM options填写-Dfile.encodin ...