浅析Python中正则表达式函数search()和match()的使用

 更新时间:2023年08月10日 10:05:20   作者:子午  
在Python中,正则表达式是处理字符串的强大工具,search()和match()是Python标准库中re模块中两个常用的正则表达式方法,本文将详细讲解这两个方法的使用,需要的可以参考一下

Python客栈送红包、纸质书

1. 正则表达式简介

正则表达式是一种描述字符串模式的表达式,用于在文本中搜索、匹配和替换字符串。它使用特定的语法规则来定义一系列字符的模式。
在Python中,re模块提供了对正则表达式的支持,通过使用search()和match()方法,我们可以进行字符串的匹配和搜索。

2. search()方法的使用

search()方法用于在整个字符串中搜索匹配正则表达式的第一个位置。如果找到匹配的子串,则返回一个匹配对象,否则返回None。

1
2
3
4
5
6
7
8
9
10
11
import re
# 定义正则表达式
pattern = r'\d+'
# 定义目标字符串
text = "Hello 123 World 456"
# 使用search()方法搜索匹配的子串
match = re.search(pattern, text)
if match:
 print("找到匹配的子串:", match.group())  # 输出:找到匹配的子串: 123
else:
 print("未找到匹配的子串")

在上述代码中,我们首先定义了一个简单的正则表达式r'\d+',用于匹配一个或多个数字。然后,我们定义了目标字符串text,其中包含数字"123"。使用search()方法搜索目标字符串中的第一个匹配子串,并输出结果。

3. match()方法的使用

match()方法用于从字符串的开头开始匹配正则表达式。如果找到匹配的子串,则返回一个匹配对象,否则返回None。

1
2
3
4
5
6
7
8
9
10
11
import re
# 定义正则表达式
pattern = r'\d+'
# 定义目标字符串
text = "123 Hello World 456"
# 使用match()方法从字符串开头开始匹配
match = re.match(pattern, text)
if match:
 print("找到匹配的子串:", match.group())  # 输出:找到匹配的子串: 123
else:
 print("未找到匹配的子串")

在上述代码中,我们将目标字符串text中的数字"123"放在字符串的开头。使用match()方法从开头开始匹配,找到了匹配子串"123"。

4. 重要的正则表达式元字符

在正则表达式中,有一些特殊字符称为元字符,它们具有特殊的含义。以下是一些重要的正则表达式元字符:

  • .:匹配除换行符外的任意字符。
  • *:匹配前面的字符0次或多次。
  • +:匹配前面的字符1次或多次。
  • ?:匹配前面的字符0次或1次。
  • ^:匹配字符串的开头。
  • $:匹配字符串的结尾。
  • []:匹配括号中的任意一个字符。
  • |:匹配两个或多个表达式中的任意一个。

这些元字符在search()和match()方法中都可以使用。

5. search()和match()的区别

search()和match()方法的主要区别在于搜索的起始位置不同:

search()方法从整个字符串中搜索第一个匹配的子串,不限制搜索的起始位置。

match()方法从字符串的开头开始匹配,只在字符串开头找到匹配的子串。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
import re
# 定义正则表达式
pattern = r'\d+'
# 定义目标字符串
text = "123 Hello World 456"
# 使用search()方法搜索匹配的子串
match_search = re.search(pattern, text)
# 使用match()方法从字符串开头开始匹配
match_match = re.match(pattern, text)
if match_search:
  print("search()找到匹配的子串:", match_search.group())  # 输出:search()找到匹配的子串: 123
else:
  print("search()未找到匹配的子串")
if match_match:
  print("match()找到匹配的子串:", match_match.group())  # 输出:match()找到匹配的子串: 123
else:
  print("match()未找到匹配的子串")

在上述代码中,我们使用search()和match()方法分别进行搜索。使用search()方法可以找到匹配的子串"123",而使用match()方法同样找到了匹配子串"123",因为"123"正好位于字符串的开头。

6. 使用编译后的正则表达式

当我们需要多次使用相同的正则表达式时,可以先对正则表达式进行编译,以提高效率。

1
2
3
4
5
6
7
8
9
10
11
12
13
import re
# 定义正则表达式
pattern = r'\d+'
# 定义目标字符串
text = "Hello 123 World 456"
# 编译正则表达式
regex = re.compile(pattern)
# 使用编译后的正则表达式进行搜索
match = regex.search(text)
if match:
  print("找到匹配的子串:", match.group())  # 输出:找到匹配的子串: 123
else:
  print("未找到匹配的子串")

在上述代码中,我们先使用re.compile()函数对正则表达式进行编译,得到一个编译后的正则表达式对象regex。然后,我们可以多次使用这个regex对象进行搜索,从而提高了效率。

7. 实例:匹配有效的邮箱地址

让我们通过一个实例来更深入了解search()和match()方法的使用。我们来编写一个正则表达式,用于匹配有效的邮箱地址。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
import re
# 定义正则表达式
pattern = r'^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$'
# 定义目标字符串
emails = [
  "user@example.com",
  "user-1@example.co.uk",
  "user.name@example.com",
  "user@sub.example.co.in",
  "invalid_email"
]
# 使用search()方法匹配有效的邮箱地址
for email in emails:
  match = re.search(pattern, email)
  if match:
      print("有效的邮箱地址:", match.group())
  else:
      print("无效的邮箱地址")

在上述代码中,我们定义了一个复杂的正则表达式,用于匹配有效的邮箱地址。然后,我们定义了一个列表emails,其中包含了一些邮箱地址。使用search()方法逐个匹配邮箱地址,并输出结果。

8. 实例:匹配日期格式

再来看一个实例,我们编写一个正则表达式,用于匹配日期的格式。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
import re
# 定义正则表达式
pattern = r'\d{4}-\d{2}-\d{2}'
# 定义目标字符串
dates = [
  "2023-07-30",
  "2023/07/30",
  "30-07-2023",
  "07-30-2023",
  "2023-13-30"
]
# 使用search()方法匹配日期格式
for date in dates:
  match = re.search(pattern, date)
  if match:
      print("匹配的日期格式:", match.group())
  else:
      print("无效的日期格式")

在上述代码中,我们定义了一个简单的正则表达式r'\d{4}-\d{2}-\d{2}',用于匹配格式为"YYYY-MM-DD"的日期。然后,我们定义了一个列表dates,其中包含了一些日期字符串。使用search()方法逐个匹配日期格式,并输出结果。

9. 总结

通过本文的讲解,我们从入门到精通了解了search()和match()这两个在Python中常用的正则表达式方法的使用。

  • search()方法用于在整个字符串中搜索匹配正则表达式的第一个位置。
  • match()方法用于从字符串的开头开始匹配正则表达式。

我们还学会了一些重要的正则表达式元字符,以及如何使用编译后的正则表达式提高效率。最后,通过实例,我们深入了解了search()和match()方法在实际应用中的使用。

掌握了这些正则表达式的基本知识和方法,我们可以更好地处理字符串,进行有效的匹配和搜索操作,从而编写出高效、灵活的Python代码。

到此这篇关于浅析Python中正则表达式函数search()和match()的使用的文章就介绍到这了,更多相关Python search match内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

蓄力AI

微信公众号搜索 “ 脚本之家 ” ,选择关注

程序猿的那些事、送书等活动等着你

原文链接:https://segmentfault.com/a/1190000044094859

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 reterry123@163.com 进行投诉反馈,一经查实,立即处理!

相关文章

  • python实现音乐播放和下载小程序功能

    python实现音乐播放和下载小程序功能

    这篇文章主要介绍了python实现音乐播放和下载小程序功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-04-04
  • tensorflow:指定gpu 限制使用量百分比,设置最小使用量的实现

    tensorflow:指定gpu 限制使用量百分比,设置最小使用量的实现

    今天小编就为大家分享一篇tensorflow:指定gpu 限制使用量百分比,设置最小使用量的实现,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-02-02
  • Python DBM模块轻松使用小型数据库存储管理数据

    Python DBM模块轻松使用小型数据库存储管理数据

    这篇文章主要介绍了Python DBM模块轻松使用小型数据库存储管理数据,它可以让你轻松地存储和管理键值对数据,可以使用 dbm 模块来操作 DBM 文件,或者使用 shelve 模块来存储任意类型的 Python 对象
    2024-01-01
  • python通过TimedRotatingFileHandler按时间切割日志

    python通过TimedRotatingFileHandler按时间切割日志

    这篇文章主要介绍了python通过TimedRotatingFileHandler按时间切割日志的方法,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-07-07
  • Python调用Java可执行jar包问题

    Python调用Java可执行jar包问题

    这篇文章主要介绍了Python调用Java可执行jar包问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • Python dataframe如何设置index

    Python dataframe如何设置index

    这篇文章主要介绍了Python dataframe如何设置index,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • Python利用wxPython模块打造ChatGPT式打字效果程序

    Python利用wxPython模块打造ChatGPT式打字效果程序

    这篇文章主要为大家介绍了如何利用Python和wxPython模块打造一个ChatGPT式打字效果程序,从而增强用户体验或提高应用程序的可读性,感兴趣的可以了解一下
    2023-05-05
  • 详解Python中魔法方法的使用

    详解Python中魔法方法的使用

    Python的魔法方法,也称为dunder(双下划线)方法,是可以让你对类添加“魔法”的特殊方法。本文主要来和大家聊聊魔法方法的使用,需要的可以参考一下
    2022-12-12
  • python zip文件 压缩

    python zip文件 压缩

    看了我前面的一系列文章,不知道你会不会觉得python是无所不能的,我现在就这感觉!如何用python进行文件压缩呢
    2008-12-12
  • python加速器numba使用详解

    python加速器numba使用详解

    本文主要介绍了python加速器numba使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-02-02

最新评论