关于Python正则表达式 findall函数问题详解
2018-03-22 16:26
811 查看
在写正则表达式的时候总会遇到不少的问题, 特别是在表达式有多个元组的时候。下面看下re模块下的findall()函数和多个表达式元组相遇的时候会出现什么样的坑。
代码如下:
import re str="a b c d" regex0=re.compile("((\w+)\s+\w+)") print(regex0.findall(str)) regex1=re.compile("(\w+)\s+\w+") print(regex1.findall(str)) regex2=re.compile("\w+\s+\w+") print(regex2.findall(str))
结果:
[('a b', 'a'), ('c d', 'c')] ['a', 'c'] ['a b', 'c d']
可能结果有点意外,下面解释一下
第一个正则表达式中是带有2个括号的,我们可以看到其输出是一个list 中包含2个 tuple
第二个正则表达式中带有1个括号,其输出的内容就是括号匹配到的内容,而不是整个表达式所匹配到的结果。
第三个正则表达式中不带有括号,其输出的内容就是整个表达式所匹配到的内容。
结论:findall()返回的是括号所匹配到的结果(如regex1),多个括号就会返回多个括号分别匹配到的结果(如regex),如果没有括号就返回就返回整条语句所匹配到的结果(如regex2)。所以在提取数据的时候就需要注意这个坑。
实际上是由其并不是python特有的,这是 正则 所特有的 , 任何一门高级语言使用正则都满足这个特点:有括号时只能匹配到括号中的内容,没有括号【相当于在最外层增加了一个括号】。在正则里面 “()” 代表的是分组的意思,一个括号代表一个分组,你只能匹配到"()"中的内容
您可能感兴趣的文章:
- 比较详细Python正则表达式操作指南(re使用)
- python正则表达式re模块详细介绍
- python的正则表达式re模块的常用方法
- Python 匹配任意字符(包括换行符)的正则表达式写法
- PYTHON正则表达式 re模块使用说明
- python利用正则表达式提取字符串
- Python中正则表达式的详细教程
- Python匹配中文的正则表达式
- python使用正则表达式提取网页URL的方法
- 零基础写python爬虫之神器正则表达式
- Python正则表达式匹配ip地址实例
- Python中正则表达式match()、search()函数及match()和search()的区别详解
- Python 中文正则表达式笔记
- python正则表达式match和search用法实例
- Python正则替换字符串函数re.sub用法示例
- Python入门篇之正则表达式
- python正则表达式中的括号匹配问题
- Python中正则表达式的用法实例汇总
相关文章推荐
- Python3正则匹配re.split,re.finditer及re.findall函数用法详解
- 关于Python正则表达式的问题
- 关于Python正则表达式的区分大小写的问题
- Python正则表达式---全部能匹配的子串迭代器finditer及findall及以中文匹配部分中文
- Python 正则表达式:findall
- Python中正则表达式match()、search()函数及match()和search()的区别详解
- 关于python下构建c模块出现error: Unable to find vcvarsall.bat问题的解决方法
- python 正则表达式 () findall
- python 正则表达式 之re.findall
- python中正则表达式 re.findall 用法
- 关于Python中正则表达式的反斜杠问题
- 【Python】正则表达式 re.findall 用法
- 关于Python中函数重载问题的思考
- 关于 regcomp()、regexec() 正则表达式的问题
- PHP正则表达式,关于PHP正则表达式的问题
- 关于正则表达式的怪问题
- 关于正则表达式问题
- Python中的正则表达式匹配中文问题
- 开博第一篇:一个关于正则表达式相关的问题
- 关于脏字典过滤问题-用正则表达式来过滤脏数据