Python基础之re模块
什么是模块?
为了编写可维护的代码,我们把很多的函数分组,分别放到不同的文件里,这样,每个文件包含的代码就相对较少,很多编程语言都采用这种组织代码的方式,在Python中,一个.py文件就称为一个模块
模块的作用?
使用模块的好处 大大提高了代码的可维护性 其次 编写代码不必从零开始 当一个模块编写完毕 就可以被其他地方引用 我们在编写程序的时候,也就经常使用其他模块 包括Python内置的模块和来自第三方的模块; 另外使用模块可以避免函数名和变量名冲突。
re模块
re模块是python标准库(Python中已经定义好的)里面的一个模块,主要用于模糊查询,应用方面为WEB 、爬虫等; re 模块 就其本质而言,正则表达式(或re)是一种小型的,高度专业的编程语言,(在Python中) 它内嵌在Python中,并通过re模块实现,正则表达式模式被编译成一系列的字节码,然后由 C编写的匹配引擎执行。
re模块使用元字符去匹配数据,元字符包括:
. 通配符(可以匹配任意类型的数据)
^ 从开头开始匹配
$ 结尾符 (返回以指定内容结尾的数据)
* 匹配(0,+00)次
+ 匹配(1,+00)次
? 匹配(0,1)次
{} 可以代替之前的三种情况 {0,}== * {1,}==+ {0,1}==? {6}匹配重复6次
[a-z] 表示范围 re.findall('q[a-z]', 'quojqkjhk') re.findall('q[a-z]*', 'quojqkjhk') 匹配多次 re.findall('q[^a-z]*', 'quojqkjhk') 匹配不是以q开头后面是字母的数据
[xyz] 字符集 匹配字符集中的任何一个字符
\ 去掉转义 使元字符失去特殊功能
() 分组 将()之间的内容定义为组,并且将匹配这个字符的表达式暂存在一个临时区域
| 表示或运算
反斜杠后边跟普通字符实现特功能:
\d 匹配十进制数 它相当于类[0-9] 将每个数字分成单个方式展示 \d+ 可以展示十位数或者百位数
\D 匹配任何非数字字符 它相当于类[^0-9]
\s 匹配任何空白字符 它相当于类[\+\n\r\f\v]
\S 匹配任何非空白字符 它相当于类[^\+\n\r\f\v]
\w 匹配任何字母数字字符 它相当于类[a-zA-Z0-9_]
\W 匹配任何非字母数字字符 它相当于类[^a-z A-Z 0-9_]
\b 匹配一个特殊字符边界 比如空格 & #等
r 或者 \\ 去掉特殊意义
分组
re.search("(?P<name>[a-z]+)\(?P<age>\d+)", "alex36wusir34xialv33").gruop('name')
re模块使用的函数:
findall() 把返回的结果放在列表中
search() 函数在字符串内查找模式匹配 只找到第一个匹配然后返回一个对象
search.gruop() 通过调用group()方法得到匹配的字符串 如果字符串没有匹配则返回空
match() 匹配成功就返回一个对象 不成功就什么都不返回 与search 不同的是它只在开始位置进行匹配
spilt() 按照指定的字符将带匹配对象进行分割 被分割的位置用空白代替
sub() 用指定的字符去替换带替换的对象
re.sub('\d+','A','jadsk56469adsdfsdf35464')
re.sub('\d','A','jadsk56469adsdfsdf35464')
re.sub('\d','A','jadsk56469adsdfsdf35464', 5)
re.subn('\d', 'A', 'jafdsf2313asfdsd5534') 返回替换的结果和替换的次数
compile() re.compile('') 编译想要匹配的规则 com=compile('\d+') com.findal('asdfds23asdf') 这样做可以使用多次
finditer() 将返回结果存在迭代器中 使用的时候 next = re.finditer('\d','asfdds231dsfs') next(ret).group()
去优先级 re.findall('www\.(?:baidu|163)\.com', 'afsdfdsf.163.comsdafsdf')
Python基础之re模块的更多相关文章
- 十八. Python基础(18)常用模块
十八. Python基础(18)常用模块 1 ● 常用模块及其用途 collections模块: 一些扩展的数据类型→Counter, deque, defaultdict, namedtuple, ...
- Python基础-包与模块
Python基础-包与模块 写在前面 如非特别说明,下文均基于Python3 摘要 为重用以及更好的维护代码,Python使用了模块与包:一个Python文件就是一个模块,包是组织模块的特殊目录(包含 ...
- python基础,函数,面向对象,模块练习
---恢复内容开始--- python基础,函数,面向对象,模块练习 1,简述python中基本数据类型中表示False的数据有哪些? # [] {} () None 0 2,位和字节的关系? # ...
- python基础31[常用模块介绍]
python基础31[常用模块介绍] python除了关键字(keywords)和内置的类型和函数(builtins),更多的功能是通过libraries(即modules)来提供的. 常用的li ...
- python基础-包和模块
Python基础-包与模块 写在前面 如非特别说明,下文均基于Python3 摘要 为重用以及更好的维护代码,Python使用了模块与包:一个Python文件就是一个模块,包是组织模块的特殊目录(包含 ...
- Python全栈开发之路 【第六篇】:Python基础之常用模块
本节内容 模块分类: 好处: 标准库: help("modules") 查看所有python自带模块列表 第三方开源模块: 自定义模块: 模块调用: import module f ...
- Python基础入门-os模块
今天我们来介绍一下os模块中常用的一些方法,当然python中的os模块中提供的使用方法有很多,但是这里面小编会列举出来一些和实际工作中应用的相关的方法,而且会有一些实际的例子方便大家对os模块理解. ...
- python基础,导入模块,if语句,while语句
python基础 python代码 变为字节码 变为机器码 最后执行执行‘文件名.py’文件时出现的‘文件名.pyc’文件为字节码 缓存机制 使用pycharm的时候在文件最开始添加下面这两行代码,中 ...
- Python 基础之re 模块
Python 基础之大话 re 在使用re模块中主要会用到一下几个方法: re.match() #从头匹配一个字符串 re.search() #浏览全部字符串,匹配第一个符合规则的字符串 re.fin ...
- python基础之os模块操作
# os模块 目录相关内置库import os# . 当前目录 .. 返回上一级目录# 1. os.path.abspath() --获取当前文件的绝对路径(不包含os模块.py) pwd# path ...
随机推荐
- Qt代码吐槽
擦,代码注释里写这么多“NB!”是要闹哪样!!
- python中shelve模块的使用
import shelve # 将序列化文件操作dump与load进行封装,写入文件的内容就是个大的字符串字典 s_dic = shelve.open("text/b.txt",w ...
- Golang安装与环境的配置
(一) 不需FQ的情况 打开https://studygolang.com/ 下载相应的系统安装包. (二) 安装与环境配置 linux: 解压到指定目录: sudo tar zxvf [安装包的下载 ...
- B/S与C/S的优缺点
B/S:Browser/Server,即浏览器/服务器架构,一般用于网站: 优点:无需安装,不需要更新客户端: 缺点:交互性差,安全性低. C/S:Client/Server,即客户端/服务器端架构 ...
- linux虚拟机时间同步
方法来源于网上,但是经过验证是可行的. 作为linux学习的新手,开始学习时总会遇到各种各样的麻烦,每次开机发现自己的虚拟机总是与当前的时间相差几个小时到几天不等,查阅网上经验,我的做法是 1.使用y ...
- 终于不再在懵逼mysql原生语句,orm超级登场
import sqlalchemy from sqlalchemy.ext.declarative import declarative_base from sqlalchemy import cre ...
- ubuntu16.04如何安装floodlight并且连接eclipse
按顺序走,亲测没出错.用的是Luna R版本的eclipse https://floodlight.atlassian.net/wiki/spaces/floodlightcontroller/pag ...
- 查看celery 队列长度
BROKER_URL = 'redis://127.0.0.1:6379/2' quque 名称:celery 查询队列长度命令: redis-cli -n 2 llen celery 注释: -n: ...
- 本地复现Flash 0day漏洞(CVE-2018-4878)
影响版本: Adobe Flash Player <= 28.0.0.137 EXP下载地址: 链接: https://pan.baidu.com/s/1_VVQfdx6gsJvEDJj51Jg ...
- zabbix监测图形界面显示方框乱码解决方法
思路如下:用Windows下中文字体进行替换,修改配置文件即可 详细步骤如下: 1.在Windows的控制面板里的字体中,选择一种中文字体,将该字体文件复制到桌面.例如,我选择了宋体 常规字体,复制到 ...