python兵器谱之re模块与正则表达式
一、正则表达式
·1.正则表达式的应用场景: 应用特有的规则,给我需要的符合规则的字符串,在字符串中只有符合条件的才会被匹配和从大段的字符串中提取需要的数据
·匹配字符串的规则:
·1.字符串:用户输入,网络获取,文件读取
·表单注册
·爬虫:从网页中批量的额获取数据
·2.正则语法
a.元字符:
· [ ] 字符组 表示一个位置上能出现的字符 [字符串] [0-9]/[a-z]/[A-Z] 表示范围
·[^ ] 非字符组
·. 除了换行符以外的任意字符
·\w 代表数字字母下划线 (符合变量规则)
·\W 除了字母数字下划线都可以匹配
·\d 表示[0-9]
·\D 除了数字
·\t Tab键 制表符
·\n Enter
·' ' 空格 空白符
·\s 空格,Tab,Enter
·\S 除了空格都能匹配到
·\b 匹配的一个单词的两端,放在字母前面就匹配首字母,放在字母后面就匹配尾字母
· \B 除了两端都可以匹配到.匹配中间的字母
·^ 匹配一个字符串的开头
·$ 匹配一个字符串的结尾 ^字符串有多长$ 要匹配的字符串就有都多长
·a | b 或 有包含关系的字符串使用或较长的字符串放左边
·() 分组 分组命名(?P<分组的名字>分组中的正则表达式)
·b.量词 (量词默认贪婪匹配(在规则内尽可能多的匹配),运用的是回溯算法,在量词后面放一个问号,就是非贪婪匹配(惰性匹配))
·{n} 重复至少n次
·? 匹配0次或者1次
· + 匹配至少一次
·* 匹配零次或者多次
··re 模块
·import re
·re.findall('正则表达式','待匹配字符串') 以列表的形式返回匹配的值,优先返回分组内的内容
·ret = re.search('正则表达式','待匹配字符串') 从左到右找到匹配的第一个,通过group(分组的组号,来显示分组内的数据)
·ret1 = ret.group() 读取获得的值 只有一项结果
·re.match('正则表达式','待匹配字符串') 默认取第一个值,即强制在正则表达式之前加一个^,必须开头以其开始
·re.split('正则表达式',切割对象) 按照正则规则来切分 在正则表达式外加括号就可以保留要切掉的对象
·re.sub('正则表达式',替换对象,要替换变量,替换次数) 按照正则规则替换,默认全部替换
·re.subn() 全部替换 ,返回里面有替换的次数
·
·re.compile('正则表达式') 对正则表达式进行预编译,返回一个编译后的表达式的字节码.在多次执行相同的正则表达式的时候,提前用他预编译,会提高效率
·re.finditer() 会返回一个迭代器,节省内存
python兵器谱之re模块与正则表达式的更多相关文章
- Python基础之re模块(正则表达式)
就其本质而言,正则表达式(或 RE)是一种小型的.高度专业化的编程语言,(在Python中)它内嵌在Python中, 并通过 re 模块实现.正则表达式模式被编译成一系列的字节码,然后由用 C 编写的 ...
- python基础13 ---函数模块3(正则表达式)
正则表达式 一.正则表达式的本质 1.正则表达式的本质(或 RE)是一种小型的.高度专业化的编程语言,(在Python中)它内嵌在Python中,并通过 re 模块实现.正则表达式模式被编译成一系列的 ...
- Python 之 【re模块的正则表达式学习】
摘要: re模块包括操作正则表达式的函数,一些工作中都需要用到,现在说明下使用方法. 使用说明: 一,re模块下的函数: 函数 描述 compile(pa ...
- python中的re模块和正则表达式基础
1.正则匹配基础知识 (1)通配符. .只匹配一个字符 >>> re.findall("p.ckname","piiickname-pockname&q ...
- python 中的re模块,正则表达式
一.re模块 re模块中常用的方法. match: 默认从字符串开头开始匹配,re.match('fun', 'funny') 可以匹配出来 'fun' match(pattern, string, ...
- (转)正则表达式与Python(RE)模块
Python正则表达式指南 原文:http://blog.csdn.net/qdx411324962/article/details/46799831 Python3(2):正则表达式与Python ...
- python之路——常用模块
阅读目录 认识模块 什么是模块 模块的导入和使用 常用模块一 collections模块 时间模块 random模块 os模块 sys模块 序列化模块 re模块 常用模块二 hashlib模块 con ...
- Python中的re模块--正则表达式
Python中的re模块--正则表达式 使用match从字符串开头匹配 以匹配国内手机号为例,通常手机号为11位,以1开头.大概是这样13509094747,(这个号码是我随便写的,请不要拨打),我们 ...
- python常用模块(1):collections模块和re模块(正则表达式详解)
从今天开始我们就要开始学习python的模块,今天先介绍两个常用模块collections和re模块.还有非常重要的正则表达式,今天学习的正则表达式需要记忆的东西非常多,希望大家可以认真记忆.按常理来 ...
随机推荐
- ASP.NET 4.5 MVC 4 无法在Windows2008的IIS7.0上解决方案
环境 : Windows2008 R2 Standard IIS 7.5 VS2012 SQL2005 最近才接触MVC4 自己做了个小实例 准备部署在 win2008 的IIS7.5 ...
- cocos2d在IOS嵌入UM应用推荐
因为cocos2d默认建立的项目,没用使用导航界面,所以如果直接导航到应用推荐页面将无法返回. 所以我做了一些修改: AppController.mm中 用导航界面包装一下默认的viewControl ...
- Useful WCF Behaviors - IErrorHandler
Behaviors in WCF are so stinking useful, and once you get past the basics of WCF they're arguably a ...
- 【Leetcode】【Medium】Best Time to Buy and Sell Stock
Say you have an array for which the ith element is the price of a given stock on day i. If you were ...
- AD诊断命令
dcdiag repadmin /showrepl "启动从dc02到dc01的复制"cmd /c "repadmin /replicate dc02 dc01 dc=u ...
- fork: retry: Resource temporarily unavailable
用户A打开文件描述符太多,超过了该用户的限制 修改用户可以打开的文件描述符数量 1.首先,用另一个用户B登录,修改/etc/security/limit.conf * soft nofile 6553 ...
- January 26 2017 Week 4 Thursday
Wasting time is robbing yourself. 浪费时间就是掠夺自己. Wasting time is not only robbing yourself, moreover, i ...
- angular中ngOnChanges与组件变化检测的关系
1.ngOnChanges只有在输入值改变的时候才会触发,如果输入值(@Input)是一个对象,改变对象内的属性的话是不会触发ngOnChanges的. 2.组件的变化检测: 2a.changeDet ...
- 两个List中的补集
/** * 获取两个List的不同元素 * @param list1 * @param list2 * @return */ private static List getDiffrent(List ...
- 【[NOI2016]区间】
发现自己的离散化姿势一直有问题 今天终于掌握了正确的姿势 虽然这并不能阻挡我noip退役爆零的历史进程 还是先来看看离散化怎么写吧,我以前都是这么写的 for(std::set<int>: ...