正则表达式,字符串的搜索与替换

对于常规的print("\\\\")输出只会进行一次转义,即输出结果就是 \\

因为一个\\代表 \
但对于re.search()。其输入的参数会被转化为正则表达式,
re.search("\\\\",)其中的参数被看作"\"正则表达式
re的第一个参数是正则表达式,第二个参数是字符串。

下面给一个为什么要第一个参数是正则表达式,而不是想搜索的字符串

你问为什么 re.search 的第一个参数必须被当作正则表达式来处理,而不是和第二个参数一样被当作普通字符串。

原因在于:re.search 的设计目的就是为了实现"正则表达式"这个功能。

1. 函数的"约定"

每个函数都有它自己的"约定"或"合同"。当程序员调用一个函数时,他们需要遵循这个约定,并传入符合要求的参数。

re.search(pattern, string) 的约定是:

  • pattern (第一个参数): 我(re.search)会把这个参数当成正则表达式模式来处理。

  • string (第二个参数): 我会把这个参数当成普通字符串数据来处理。

如果你不遵循这个约定,函数就无法正常工作。

2. 为什么不能都当作普通字符串?

如果你将两个参数都当作普通字符串,那么 re.search 就失去了它作为"正则表达式引擎"的意义,它就退化成了一个简单的字符串查找函数,和 Python 内置的 string.find()string.index() 一样。

比如,你想用 re.search 找到一个数字 \d。如果它把 \d 当作普通字符串,它就只会去寻找字面量 \d,而永远找不到数字。

3. 命名约定

这也是为什么 re.search 的参数名是 patternstring

  • pattern 这个词本身就暗示它是一个模式。

  • string 则表示它是一个普通的数据字符串。


例子:string.find() vs. re.search()

为了更好地理解这一点,我们来比较一下 Python 内置的两种查找方法:

复制代码
text = "The quick brown fox jumped over 123 dogs."

# 使用普通的字符串查找方法
print(text.find("fox"))  # 输出: 16 (找到'fox'的索引)
print(text.find("\d"))  # 输出: -1 (因为找不到字面量"\d")

# 使用正则表达式查找方法
import re
print(re.search(r"fox", text).group())  # 输出: 'fox'
print(re.search(r"\d", text).group())   # 输出: '1' (找到第一个数字)

在这个例子中,text.find() 只能进行字面量匹配,因为它将两个参数都视为普通字符串。

re.search() 知道它的第一个参数是模式 ,所以它能理解 \d 的特殊含义,并找到数字。

所以,第一个参数被当作正则表达式来解析,是因为这就是 re.search 函数的全部意义所在。

相关推荐
叫我詹躲躲21 小时前
别再手写正则了!20 + 证件 / 手机号 / 邮箱验证函数,直接复制能用
前端·javascript·正则表达式
Moonbit2 天前
MoonBit Pearls Vol.9:正则表达式引擎的两种实现方法:导数与 Thompson 虚拟机
后端·正则表达式·编程语言
半梦半醒*12 天前
正则表达式
linux·运维·开发语言·正则表达式·centos·运维开发
PyHaVolask12 天前
Python进阶教程:随机数、正则表达式与异常处理
python·正则表达式·异常处理·随机数生成
神秘人X70713 天前
正则表达式笔记
正则表达式·shell·脚本
然我15 天前
前端正则面试通关指南:一篇吃透所有核心考点,轻松突围面试
前端·面试·正则表达式
Lynnxiaowen17 天前
今天继续昨天的正则表达式进行学习
linux·运维·学习·正则表达式·云计算·bash
前端世界20 天前
Python 正则表达式实战:用 Match 对象轻松解析拼接数据流
python·正则表达式·php
Edward.W21 天前
别再和正则表达式死磕了!这套AI工具集让你的开发效率翻倍⚙️[特殊字符]
人工智能·正则表达式
beijingliushao21 天前
58-正则表达式
数据库·python·mysql·正则表达式