python 教程 第十六章、 正则表达式
第十六章、 正则表达式
1) 匹配多个表达式
记号 re1|re2
说明 匹配正则表达式re1或re2
举例 foo|bar 匹配 foo, bar
记号 {N}
说明 匹配前面出现的正则表达式N
举例 [0-9]{3} 匹配
2) 匹配单个/多个/范围内字符
记号 .
说明 匹配任何字符(换行符除外)
举例 b.b 匹配 b和b中间有一个任意字符bab, bcb, bbb
举例 .. (匹配任何两个字符) 匹配 xx, ab
记号 […]
说明 匹配字符组里面出现的任意一个字符
举例 b[aeiou]t 匹配3字符串 bat,bit,but,bet
举例 [ab][23][xy] 匹配3字符串 a2x,a3y,b2x,b3x
记号 [..x-y..]
说明 匹配从字符x到y中的任意一个字符
举例 [0-9] 匹配任意一个十进制数字,
[A-Za-z] 匹配任意一个字母
3) 匹配开头结尾边界
记号 ^
说明 匹配字符串的开始
举例 ^Dear 匹配 任何以Dear开始的字符串
记号 $
说明 匹配字符串的结尾
举例 /bin/*sh$ 匹配 任何以/bin/*sh结束的字符串
4) 否定范围
记号 [^…]
说明 不匹配此字符集中出现的任何一个字符,包括某一范围的字符
举例 [^aeiou]匹配
[^A-Za-z0-9] 匹配
5) 多次出现/重复匹配
记号 *
说明 匹配前面出现的正则表达式零次或多次
举例 [A-Za-z0-9]* 匹配 a
记号 +
说明 匹配前面出现的正则表达式一次或多次
举例 [a-z]+\.com 匹配 qq.com, baidu.com
记号 ?
说明 匹配前面出现的正则表达式零次或一次
举例 goo? 匹配 go,goo
0?[1-9]匹配1到9的任意数字,前面可能有个0
记号 {M,N}
说明 匹配重复出现M次到N次的正则表达式
举例 [0-9]{5,10} 匹配5到9位数字,如QQ号码
[KQRBNP][a-h][1-8]-[a-h][1-8]国际象棋合法移动
记号 (*|+|?{})?
说明 用于上面出现的任何”非贪婪”.版本重复匹配次数符号
举例 .*?[a-z] 匹配
6) 特殊字符
记号 \d
说明 匹配任何数字,和[0-9]一样(\D为\d的反义,任何非数字符)
举例 data\d+.txt 匹配data后面一个或多个数字.txt
\d{3}-\d(3)-d{4} 匹配美国电话号码,如800-555-1212
记号 \w
说明 匹配任何数字字母字符,和[A-Za-z0-9_]相同,(\W为\w的反义)
举例 [A-Za-z_]\w+ 匹配任意字母再加任意一个字母或数字
\w+@\w+\.com 匹配一个电子邮件,如xxx@yyy.com
记号 \s
说明 匹配任何空白符,和[\n\t\r\v\f]相同(\S是\s的反义)
举例 of\sthe 匹配 of the
记号 \b
说明 匹配单词边界(\B是\b的反义)
举例 \bthe\b 仅匹配单词the
/bthe 任何以the开始的字符串
记号 \nn
说明 匹配已保存的子组(参考(…))
举例 price:\16 匹配
记号 \c
说明 逐一匹配特殊字符c(即取消特殊含义,按字面匹配)
举例 \.,\\,\* 匹配
记号 \A(\Z)
说明 匹配字符串的起始(结束)
举例 \ADear 以Dear开始的字符串
7) 用圆括号组建组
记号 (…)
说明 匹配封闭括号中正则表达式(RE),并保存为子组
举例 ([0-9]{3})?, f(oo|u)bar 匹配
\d+(\.\d*)? 匹配浮点型数字,任意十进制数字加一个可选小数部分(包括一个小数点,零个或多个十进制数字),如0.004,75等.
8) 其它
记号 literal
说明 匹配字符串的值
举例 foo 匹配 foo
import re;
patt = '(\w+)-(\d+)'
strg = 'abc-123'
m = re.match(patt, strg)
print m.group() #abc-123 //所有匹配部分
print m.group(1) #abc //匹配的子组1
print m.group(2) #123 //匹配的子组2
print m.groups() #('abc', '123') //所有匹配子组
findall找个每个匹配的部分
>>> re.findall('car', 'carry the car') #['car', 'car']
sub搜索替换
>>> re.sub('X', 'Mr.Smith', 'Dear X') #'Dear Mr.Smith'
subn搜索替换并返回次数
>>> re.subn('X', 'Mr.Smith', 'Dear X') #('Dear Mr.Smith', 1)
split分割字符串
>>> re.split(':', 'str1:str2:str3') #['str1', 'str2', 'str3']
贪婪匹配
data = ':1234567-8-9'
print re.search('\d+-\d+-\d+', data).group() #1234567-8-9
print re.match('.+\d+-\d+-\d+', data).group() #:1234567-8-9
print re.match('.+(\d+-\d+-\d+)', data).group(1) #7-8-9
print re.match('.+?(\d+-\d+-\d+)', data).group(1) #1234567-8-9
python 教程 第十六章、 正则表达式的更多相关文章
- 进击的Python【第十六章】:Web前端基础之jQuery
进击的Python[第十六章]:Web前端基础之jQuery 一.什么是 jQuery ? jQuery是一个JavaScript函数库. jQuery是一个轻量级的"写的少,做的多&quo ...
- Flask 教程 第十六章:全文搜索
本文翻译自The Flask Mega-Tutorial Part XVI: Full-Text Search 这是Flask Mega-Tutorial系列的第十六部分,我将在其中为Microblo ...
- python 教程 第二十二章、 其它应用
第二十二章. 其它应用 1) Web服务 ##代码 s 000063.SZ ##开盘 o 26.60 ##最高 h 27.05 ##最低 g 26.52 ##最新 l1 26.66 ##涨跌 c ...
- python 教程 第十五章、 结构布局
第十五章. 结构布局 #!/usr/bin/env python #(1)起始行 "this is a module" #(2)模块文档 import sys #(3)模块导入 d ...
- python 教程 第十四章、 地址薄作业
第十四章. 地址薄作业 #A Byte of Python #!/usr/bin/env python import cPickle import os #define the contacts fi ...
- python 教程 第十二章、 标准库
第十二章. 标准库 See Python Manuals ? The Python Standard Library ? 1) sys模块 import sys if len(sys.argv) ...
- python 教程 第十九章、 图形界面编程
第十九章. 图形界面编程 import Tkinter top = Tkinter.Tk() hello = Tkinter.Label(top, text='Hello World!') hello ...
- C#图解教程 第十六章 转换
转换 什么是转换隐式转换显式转换和强制转换 强制转换 转换的类型数字的转换 隐式数字转换溢出检测上下文 1.checked和unchecked运算符2.checked语句和unchecked语句 显式 ...
- 进击的Python【第十四章】:Web前端基础之Javascript
进击的Python[第十四章]:Web前端基础之Javascript 一.javascript是什么 JavaScript 是一种轻量级的编程语言. JavaScript 是可插入 HTML 页面的编 ...
随机推荐
- Mahout快速入门教程 分类: B10_计算机基础 2015-03-07 16:20 508人阅读 评论(0) 收藏
Mahout 是一个很强大的数据挖掘工具,是一个分布式机器学习算法的集合,包括:被称为Taste的分布式协同过滤的实现.分类.聚类等.Mahout最大的优点就是基于hadoop实现,把很多以前运行于单 ...
- Android Widget和悬浮窗 原理
1.简单介绍 Android widget是桌面插件,在android系统应用开发层面有特殊用途. AppWidget是把一个进程的控件嵌入到别外一个进程的窗口里的一种方法.悬浮窗的效果与Widget ...
- SocketChannel API用法
java.nio.channels 类 SocketChannel java.lang.Object java.nio.channels.spi.AbstractInterruptibleChanne ...
- 最全面的iOS和Mac开源项目和第三方库汇总
标签: UI 下拉刷新 EGOTableViewPullRefresh – 最早的下拉刷新控件. SVPullToRefresh – 下拉刷新控件. MJRefresh – 仅需一行代码就可以为UIT ...
- php实现找两个链表的第一个公共结点(实例演示)
php实现找两个链表的第一个公共结点(实例演示) 一.总结 因为是链表,第一个节点公共之后,后面所有的节点都公共了 画个图实例演示一下,会超清晰且简单 二.php实现找两个链表的第一个公共结点 题目描 ...
- Mysql 安装(Using Generic Binaries)
本次 Mysql 为Community 5.6.21 版本号.安装方式为通用Linux安装方式.即大多数Linux平台都能够採用该方式进行安装. 一.安装步骤 1.安装环境 1)Centos 7.0. ...
- PHP 根据对象属性进行对象数组的排序(usort($your_data, "cmp");)(inside the class: usort($your_data, array($this, "cmp")))
PHP 根据对象属性进行对象数组的排序(usort($your_data, "cmp");)(inside the class: usort($your_data, array($ ...
- [Angular] Using directive to create a simple Credit card validator
We will use 'HostListener' and 'HostBinding' to accomplish the task. The HTML: <label> Credit ...
- SpringMVC大坑一枚:ContentNegotiatingViewResolver可能不利于SEO
广大站长都有关注自己网站被搜索引擎收录的习惯,最近用百度.360等搜索引擎,查看了自己网站的一些情况,使用命令"site:fansunion.cn". 我发现了一些异常信息,不止一 ...
- WPF Chart 图标
DevExpress: <dxc:ChartControl.Diagram> <dxc:XYDiagram2D.SeriesTemplate> </dxc:XYDiagr ...