脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|shell|

服务器之家 - 脚本之家 - Python - Python3中的re.findall()方法及re.compile()

Python3中的re.findall()方法及re.compile()

2023-02-02 15:33Rustone Python

这篇文章主要介绍了Python3中的re.findall()方法及re.compile(),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

re.findall()方法及re.compile()

  • re.findall()在字符串中找到正则表达式所匹配的所有子串,并返回一个列表;如果没有找到匹配的,则返回空列表。

返回结果是列表类型,需要遍历一下才能依次获取每组内容。

?
1
findall(patern, string, flags=0)
  • pattern : 正则中的模式字符串。
  • string : 要被查找替换的原始字符串。
  • flags : 标志位,用于控制正则表达式的匹配方式,如:是否区分大小写,多行匹配等等。

1.例子

?
1
2
3
4
5
6
7
import re 
content = 'Hello 123456789 Word_This is just a test 666 Test'
results = re.findall('\d+', content)    
 
print(results)
for result in results:
    print(result)

结果:

['123456789', '666']
123456789
666
 
Process finished with exit code 0

注意利用re.findall()函数没有group()和groups(),因为其返回结果是一个列表。

2.re.compile()方法

  • re.compile()方法可以将正则字符串编译成正则表达式对象,以便在后面的匹配中复用。
?
1
re.compile(pattern[, flags])

re.compile()中可以传入忽略换行等匹配模式,这样在search()、findall()方法中就不需要额外传入了。

因此,re.findall()方法有2种表达方式:

?
1
2
3
4
5
6
7
8
9
10
11
import re
 
content = 'one1two22three333four4444'
pattern = re.compile(r'\d+')
print('===方法1:===')
result1 = re.findall(pattern, content)
print(result1)
 
print('===方法2===')
result2 = pattern.findall(content)
print(result2)

结果:

===方法1:===
['1', '22', '333', '4444']
===方法2===
['1', '22', '333', '4444']
 
Process finished with exit code 0

3.在使用findall()方法时的“坑”

注意正则表达式中括号()的使用

(1)正则表达式中当没有括号时,正常匹配:

?
1
2
3
4
5
import re 
 
str1 = '2345  3456  4567  5678  6789'
pattern_1 = re.compile('\w+\s+\w+') # \w 表示匹配包括下划线的任何单词字符,等价于[A-Za-z0-9_]
print(pattern_1.findall(str1))

结果:

['2345  3456', '4567  5678']
 
Process finished with exit code 0

(2)正则表达式中有一个括号时,其输出的内容就是括号匹配到的内容,而不是整个表达式所匹配到的结果:

?
1
2
3
4
5
import re
 
str1 = '2345  3456  4567  5678  6789'
pattern_1 = re.compile('(\w+)\s+\w+') # \w 表示匹配包括下划线的任何单词字符,等价于[A-Za-z0-9_]
print(pattern_1.findall(str1))

结果:

['2345', '4567']
 
Process finished with exit code 0

整个正则表达式执行了,只不过只输出括号匹配到的内容,即输出的是第一个 (\w+) 匹配到的内容:

在第一次匹配时跟上述没有括号时一样,匹配到"2345 3456",只不过只输出(/w+)匹配到的结果 即"2345";

第二次匹配同理,从"4567" 开始,匹配到"4567  5678",但是还是只是输出(/w+)匹配到的结果 即"4567"。

(3)当正则表达式中有两个括号时,其输出是一个list 中包含2个 tuple:

?
1
2
3
4
5
import re
 
str1 = '2345  3456  4567  5678  6789'
pattern_1 = re.compile('((\w+)\s+\w+)') # \w 表示匹配包括下划线的任何单词字符,等价于[A-Za-z0-9_]
print(pattern_1.findall(str1))

结果:

[('2345  3456', '2345'), ('4567  5678', '4567')]
 
Process finished with exit code 0

从输出的结果可以看出,结果中包含两个元组,每一个元组中有两个字符串。

第一个元组是第一次匹配的结果,其中的第一个字符串 "2345 3456" 是正则表达式最外面的括号

  • ((\w+)\s+\w+)

匹配输出的结果;

第一个元组中的第二个字符串 "2345"是正则表达式里面括号

  • (\w+)

匹配输出的结果 ;

第二个元组是第二次匹配的结果,匹配原理与第一次匹配相同。

正则表达式findall函数问题

在写正则表达式的时候总会遇到不少的问题, 特别是在表达式有多个元组的时候。下面看下re模块下的findall()函数和多个表达式元组相遇的时候会出现什么样的坑。

代码如下:    

?
1
2
3
4
5
6
7
8
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特有的,这是 正则 所特有的 , 任何一门高级语言使用正则都满足这个特点:有括号时只能匹配到括号中的内容,没有括号【相当于在最外层增加了一个括号】。在正则里面 “()” 代表的是分组的意思,一个括号代表一个分组,你只能匹配到"()"中的内容

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/m0_37360684/article/details/84141176

延伸 · 阅读

精彩推荐
  • PythonPython Pytorch深度学习之数据加载和处理

    Python Pytorch深度学习之数据加载和处理

    今天小编就为大家分享一篇Pytorch 数据加载与数据预处理方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    柚子味的羊11282022-02-19
  • PythonPython中decorator使用实例

    Python中decorator使用实例

    这篇文章主要介绍了Python中decorator使用实例,本文讲解了如何调用decorator、decorator函数的定义、decorator的应用场景等内容,需要的朋友可以参考下 ...

    脚本之家4832020-06-05
  • PythonPython实现的用户登录系统功能示例

    Python实现的用户登录系统功能示例

    这篇文章主要介绍了Python实现的用户登录系统功能,涉及Python流程控制及字符串判断等相关操作技巧,需要的朋友可以参考下...

    毕加索的ma12662021-01-12
  • PythonDjango+Uwsgi+Nginx如何实现生产环境部署

    Django+Uwsgi+Nginx如何实现生产环境部署

    这篇文章主要介绍了Django+Uwsgi+Nginx如何实现生产环境部署,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友...

    金角大王Alex6722020-08-01
  • Pythonpython如何实现异步调用函数执行

    python如何实现异步调用函数执行

    这篇文章主要介绍了python如何实现异步调用函数执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以...

    迎风而来7402021-08-04
  • Pythonpython else语句在循环中的运用详解

    python else语句在循环中的运用详解

    这篇文章主要介绍了python else语句在循环中的运用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友...

    abraham_ly3232020-07-07
  • PythonPython使用Selenium爬取淘宝异步加载的数据方法

    Python使用Selenium爬取淘宝异步加载的数据方法

    今天小编就为大家分享一篇Python使用Selenium爬取淘宝异步加载的数据方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    wqh_jingsong7162021-04-30
  • Pythonpyinstaller打包exe程序的步骤和添加依赖文件的实现

    pyinstaller打包exe程序的步骤和添加依赖文件的实现

    这篇文章主要介绍了pyinstaller打包exe程序的步骤和添加依赖文件的实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,...

    Spider.Li5392022-09-16