re模块下的常用方法
一 : re模块的查找
findall 优先级查找 返回列表 找所有的匹配项(从大段的内容中找匹配到的项目)
import re
str = "qwer asdf zxcv qwerasd"
ret =re.compile("\w+\s\w+") #第一种没有括号的
print(ret.findall(str)) # 结果 : ['qwer asdf', 'zxcv qwerassd'] str = "qwer asdf zxcv qwerasd"
ret =re.compile("(\w+)\s\w+") #第二种有一个括号的
print(ret.findall(str)) #结果 : ['qwer', 'zxcv'] str = "qwer asdf zxcv qwerasd"
ret =re.compile("((\w+)\s\w+)") #第三种有两个括号的
print(ret.findall(str)) #结果 : [('qwer asdf', 'qwer'), ('zxcv qwerassd', 'zxcv')]
search: 只匹配从左到右的第一个,得到的不是直接结果,得到的是一个变量,通过这个变量的group方法来获取结果,如果没有匹配到返回None,group会报错.
import re
ret = re.research('\d+',"sjkhk172按实际花费928")
print (ret) #内存地址,这是一个正则匹配的结果
print(ret.group()) #通过ret.group()获取真正的结果 #<_sre.SRE_Match object; span=(5, 8), match='172'> #
ret = re.search('\d','owghabDJLBNdgv')
print(ret) #None
print(ret.group()) #会报错
match:相当于search的正则表达式中加个" ^ "
import re
ret = re.match('\d+',"172sjkhk按实际花费928") #match相当于在\d前加' ^'
print(ret) #地址
print(ret.group()) #匹配到的内容 #<_sre.SRE_Match object; span=(0, 3), match='172'>
#
spile:字符串扩展的处理 替换 切割
s = 'alex|taibai|egon|'
print(s.split('|')) #结果 :['alex', 'taibai', 'egon', ''] import re
s = 'alex83taibai40egon25'
ret = re.split('\d+',s)
print(ret) #['alex', 'taibai', 'egon', '']
sub/subn :替换,按照正则规则取寻找要被替换的内容,subn返回被替换的元组,第二个值是被替换的次数
ret = re.sub('\d+','H','alex83taibai40egon25')
print(ret)
ret = re.sub('\d+','H','alex83taibai40egon25',1) #这里的1是替换一次
print(ret)
subn 返回一个元组#,第二个元素是替换的次数
# ret = re.subn('\d+','H','alex83taibai40egon25')
# print(ret)
#alexHtaibaiHegonH
#alexHtaibai40egon25
#('alexHtaibaiHegonH', 3) #这里的3是指替换了3次
compile 编译一个正则表达式用这个结果取search , match , findall , finditer 能够节省时间
ret = re.compile('\d+') #已经完成编译
res = ret.findall('alex83taibai40egon25')
print(res)
#['83', '40', '25']
res = re.search('sjkhk172按实际花费928')
print(res)
#
finditer 节省你使用正则表达式解决问题的空间/内存
返回一个迭代器,所有的结果都在这个迭代器中,需要
ret = re.finditer('\d+','alex83taibai40egon25')
for i in ret:
print(i.group())
#
#
#
总结:
#findall 返回列表 找所有的匹配项
# search 匹配就 返回一个变量,通过group取匹配到的第一个值,不匹配就返#回None,group会报错
# match 相当于search的正则表达式中加了一个'^' # spilt 返回列表,按照正则规则切割,默认匹配到的内容会被切掉
# sub/subn 替换,按照正则规则去寻找要被替换掉的内容,subn返回元组,第二#个值是替换的次数 # compile 编译一个正则表达式,用这个结果去search match findall #finditer 能够节省时间
# finditer 返回一个迭代器,所有的结果都在这个迭代器中,需要通过循环#+group的形式取值 能够节省内存
re模块下的常用方法的更多相关文章
- re模块下的的常用方法
引入模块: import re 1.查找findall 匹配所有,每一项都是列表中的一个元素 ret=re.findall("\d+","sjkhk172按实际花费9 ...
- Flex4分模块下样式动态加载步骤及相关问题的解决
1. 给应用程序编写CSS文件 (1)在项目下创建CSS文件(任意路径,可以多个).本例在src下创建了5个样式文件 (2)Flex支持的CSS文件定义如下: a) type selector(类 ...
- thinkphp6.0 多应用模块下提示控制器不存在
thinkphp6.0 多应用模块下提示控制器不存在 在项目根目录下使用Composer composer require topthink/think-multi-app 参考链接
- python学习笔记五 模块下(基础篇)
shevle 模块 扩展pickle模块... 1.潜在的陷进 >>> import shelve>>> s = shelve.open("nb" ...
- phpcms v9 源码解析(4)content模块下的index.php文件的init()方法解析
在了解index.php中的init函数的时候,让我们先看看最开始的几行代码 1-5 第二行, defined('IN_PHPCMS') or exit('Nopermission resource ...
- “死锁” 与 python多线程之threading模块下的锁机制
一:死锁 在死锁之前需要先了解的概念是“可抢占资源”与“不可抢占资源”[此处的资源可以是硬件设备也可以是一组信息],因为死锁是与不可抢占资源有关的. 可抢占资源:可以从拥有他的进程中抢占而不会发生副作 ...
- 摘要算法---hashlib模块下MD5和SHA的使用
作用: 任意长度的字符串内容通过摘要算法都可以生成唯一序列摘要值,通过摘要算法,可以校验某个文档或者某组字符串是否被修改. 应用: 1.文件内容一致性校验 2.用户登录验证 常用方法 update() ...
- Yii2访问自定义模块下的controller
之前,由于所要访问的controller都是位于根目录下的controllers目录下,就像下面这样: 此时,我们可以直接通过 localhost/basic/web/index.php?r=dao/ ...
- SpringBoot(九):多模块下mapper分散后无法启动SpringBoot解决方法
问题描述: SpringBoot项目之前是一个项目*-web,运行没问题,后来将项目拆分为多个项目,就出现启动失败问题. SpringBoot项目结构: 项目被分为多块:*-mapper(mybati ...
随机推荐
- vue的事件绑定
vue事件有两方面内容:DOM事件 和 自定义事件. DOM事件 vue中采用DOM2级事件的处理方式,为IE9以上的浏览器服务.下面我们先来讲解一下什么是DOM2级事件吧! JS中DOM0级事件有两 ...
- php5 常量
<?php define("GREETING", "Welcome to w3cschool.cn!", true); echo greeting; ?& ...
- SVN客户端操作(clean up|commit|update)系统找不到指定的文件
前天电脑中毒,更新SVN的时候,发现以下错误: Can't open file 'XXXXX\.svn\pristine\7a\7ab8cc591cd8b0425a0e6331cc52756d15ba ...
- token流程图
- json原生解析
身为新手,在运用网络解析json数据的时候,发现先会用Gson等框架解析json,然后就懒起来学原生解析了,这下在看别人写的demo的时候就尴尬了,一块块的,不懂写什么,气氛十分尴尬. 不多说,先来条 ...
- spring boot 使用POI导出数据到Excel表格
在spring boot 的项目经常碰到将数据导出到Excel表格的需求,而POI技术则对于java操作Excel表格提供了API,POI中对于多种类型的文档都提供了操作的接口,但是其对于Excel表 ...
- 为什么无法定义1px左右高度的容器
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xht ...
- Swift 之类的继承与类的访问权限
http://www.cocoachina.com/swift/20160104/14821.html 上一篇博客<窥探Swift之别具一格的Struct和Class>的博客可谓是给Swi ...
- Leetcode704.Binary Search二分查找
给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1. 示例 1: 输入: num ...
- 【POJ 3261】Milk Patterns
[链接]h在这里写链接 [题意] 给你一个长度为n的序列. 问你能不能在其中找到一个最长的子串. 这个子串至少出现了k次. [题解] 长度越长,就越不可能出现k次 后缀数组+二分. N最大为2 ...