位置: 编程技术 - 正文
推荐整理分享Python基础教程之正则表达式基本语法以及re模块(python基础教程chm),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:python0基础教程,python基础教程 入门教程,python基础教程 入门教程,python 基础 教程,python基础教程 zol,python基础教程 zol,python 基础 教程,python基础教程 zol,内容如对您有帮助,希望把文章链接给更多的朋友!
什么是正则:
正则表达式是可以匹配文本片段的模式。
正则表达式'Python'可以匹配'python'
正则是个很牛逼的东西,python中当然也不会缺少。
所以今天的Python就跟大家一起讨论一下python中的re模块。
re模块包含对正则表达式的支持。
通配符
.表示匹配任何字符:
‘.ython'可以匹配'python'和'fython'
对特殊字符进行转义:
‘python.org'匹配‘python.org'
字符集
‘[pj]ython'能够匹配'python'和'jython'
反转字符集
‘[^abc]'可以匹配除了abc之外的任何字符
选择符
使用管道符号|
可选项
加上问好就变为了可选项:
r'(
*:允许模式重复0次或多次 +:允许模式重复1次或多次 {m, n}允许模式重复m-n次
当然,正则语法规则很多,远不止上面的这些。但是我们只能点到为止了,因为这篇博客的目的是介绍Python中的模块,re模块。
re 模块使 Python 语言拥有全部的正则表达式功能。
compile 函数根据一个模式字符串和可选的标志参数生成一个正则表达式对象。该对象拥有一系列方法用于正则表达式匹配和替换。
re 模块也提供了与这些方法功能完全一致的函数,这些函数使用一个模式字符串做为它们的第一个参数。
re中重要的函数:
compile(pattern[, flags]) 根据包含正则表达式的字符串创建模式对象
search(pattern, string[, flags]) 在字符串中寻找模式
match(pattern, string[, flags]) 在字符串的开始处匹配模式
split(pattern, string[, maxsplit=0]) 根据匹配项分割字符串
findall(pattern, string) 列出字符串中模式的所有匹配项
sub(pat, rep, string[, count=0]) 字符串中所有pat的匹配项用repl替换
escape(string) 将字符串中所有特殊表达式字符转义
下面就进行简单的应用:
使用match
使用search
这时候需要停一下,match和search的区别呢?
看看结果先:
match例子中结果:
(0, 3)None
search例子中结果:
(0, 3)(, )
match()函数只检测RE是不是在string的开始位置匹配,search()会扫描整个string查找匹配; 也就是说match()只有在0位置匹配成功的话才有返回,如果不是开始位置匹配成功的话,match()就返回none。
search()会扫描整个字符串并返回第一个成功的匹配。
使用sub
Python 的re模块提供了re.sub用于替换字符串中的匹配项。
结果:
Phone Num : --Phone Num :
最后献上菊花:
^ 匹配字符串的开头$ 匹配字符串的末尾。. 匹配任意字符,除了换行符,当re.DOTALL标记被指定时,则可以匹配包括换行符的任意字符。[...] 用来表示一组字符,单独列出:[amk] 匹配 'a','m'或'k'[^...] 不在[]中的字符:[^abc] 匹配除了a,b,c之外的字符。re* 匹配0个或多个的表达式。re+ 匹配1个或多个的表达式。re 匹配0个或1个由前面的正则表达式定义的片段,非贪婪方式re{ n} re{ n,} 精确匹配n个前面表达式。re{ n, m} 匹配 n 到 m 次由前面的正则表达式定义的片段,贪婪方式a| b 匹配a或b(re) G匹配括号内的表达式,也表示一个组(imx) 正则表达式包含三种可选标志:i, m, 或 x 。只影响括号中的区域。(-imx) 正则表达式关闭 i, m, 或 x 可选标志。只影响括号中的区域。(: re) 类似 (...), 但是不表示一个组(imx: re) 在括号中使用i, m, 或 x 可选标志(-imx: re) 在括号中不使用i, m, 或 x 可选标志(#...) 注释.(= re) 前向肯定界定符。如果所含正则表达式,以 ... 表示,在当前位置成功匹配时成功,否则失败。但一旦所含表达式已经尝试,匹配引擎根本没有提高;模式的剩余部分还要尝试界定符的右边。(! re) 前向否定界定符。与肯定界定符相反;当所含表达式不能在字符串当前位置匹配时成功(> re) 匹配的独立模式,省去回溯。w 匹配字母数字W 匹配非字母数字s 匹配任意空白字符,等价于 [tnrf].S 匹配任意非空字符d 匹配任意数字,等价于 [0-9].D 匹配任意非数字A 匹配字符串开始Z 匹配字符串结束,如果是存在换行,只匹配到换行前的结束字符串。cz 匹配字符串结束G 匹配最后匹配完成的位置。b 匹配一个单词边界,也就是指单词和空格间的位置。例如, 'erb' 可以匹配"never" 中的 'er',但不能匹配 "verb" 中的 'er'。B 匹配非单词边界。'erB' 能匹配 "verb" 中的 'er',但不能匹配 "never" 中的 'er'。n, t, 等. 匹配一个换行符。匹配一个制表符。等1...9 匹配第n个分组的子表达式。 匹配第n个分组的子表达式,如果它经匹配。否则指的是八进制字符码的表达式。
re的正则表达式语法
正则表达式语法表如下:
语法 意义 说明 "." 任意字符 "^" 字符串开始 '^hello'匹配'helloworld'而不匹配'aaaahellobbb' "$" 字符串结尾 与上同理 "*" 0 个或多个字符(贪婪匹配) <*>匹配 "+" 1 个或多个字符(贪婪匹配) 与上同理 "" 0 个或多个字符(贪婪匹配) 与上同理 *,+, 以上三个取第一个匹配结果(非贪婪匹配) <*>匹配
用Python实现斐波那契(Fibonacci)函数 Fibonacci斐波那契数列,很简单,就是一个递归嘛,学任何编程语言可能都会做一下这个。最近在玩Python,在粗略的看了一下LearningPython和CorePython之后,
python Django批量导入不重复数据 本文为大家分享了pythonDjango批量导入不重复数据的实现代码,供大家参考,具体内容如下程序如下:#coding:utf-8importosos.environ.setdefault("DJANGO_SETTINGS_MODULE",
python Django批量导入数据 前言:这期间有研究了Django网页制作过程中,如何将数据批量导入到数据库中.这个过程真的是惨不忍睹,犯了很多的低级错误,这会在正文中说到的.再者导
标签: python基础教程chm
本文链接地址:https://www.jiuchutong.com/biancheng/384403.html 转载请保留说明!友情链接: 武汉网站建设