re.sub 功能

re.sub的功能

re是regular expression的所写,表示正则表达式

sub是substitute的所写,表示替换;

re.sub是个正则表达式方面的函数,用来实现通过正则表达式,实现比普通字符串的replace更加强大的替换功能;

举个最简单的例子:

如果输入字符串是:

inputStr = "hello 111 world 111"
 
  • 1
  • 1

那么你可以通过

replacedStr = inputStr.replace("111", "222")
 
  • 1
  • 1

去换成

"hello 222 world 222"
 
  • 1
  • 1

但是,如果输入字符串是:

inputStr = "hello 123 world 456"
 
  • 1
  • 1

而你是想把123和456,都换成222

(以及其他还有更多的复杂的情况的时候),

那么就没法直接通过字符串的replace达到这一目的了。

就需要借助于re.sub,通过正则表达式,来实现这种相对复杂的字符串的替换:

replacedStr = re.sub("\d+", "222", inputStr)
 
  • 1
  • 1

当然,实际情况中,会有比这个例子更加复杂的,其他各种特殊情况,就只能通过此re.sub去实现如此复杂的替换的功能了。

所以,re.sub的含义,作用,功能就是:

对于输入的一个字符串,利用正则表达式(的强大的字符串处理功能),去实现(相对复杂的)字符串替换处理,然后返回被替换后的字符串

其中re.sub还支持各种参数,比如count指定要替换的个数等等。

下面就是来详细解释其各个参数的含义。

re.sub的各个参数的详细解释

re.sub共有五个参数。

re.sub(pattern, repl, string, count=0, flags=0)

其中三个必选参数:pattern, repl, string

两个可选参数:count, flags

第一个参数:pattern

pattern,表示正则中的模式字符串,这个没太多要解释的。

需要知道的是:

  • 反斜杠加数字(\N),则对应着匹配的组(matched group)
    比如\6,表示匹配前面pattern中的第6个group
    意味着,pattern中,前面肯定是存在对应的,第6个group,然后你后面也才能去引用

    比如,想要处理:

    hello crifan, nihao crifan
       
    • 1
    • 1

    且此处的,前后的crifan,肯定是一样的。

    而想要把整个这样的字符串,换成crifanli

    则就可以这样的re.sub实现替换:

    inputStr = "hello crifan, nihao crifan";
    replacedStr = re.sub(r"hello (\w+), nihao \1", "crifanli", inputStr);
       
    • 1
    • 2
    • 1
    • 2

    第二个参数:repl

    repl,就是replacement,被替换,的字符串的意思。

    repl可以是字符串,也可以是函数。

    repl是字符串

    如果repl是字符串的话,其中的任何反斜杠转义字符,都会被处理的。

    即:

  • \n:会被处理为对应的换行符;
  • \r:会被处理为回车符;
  • 其他不能识别的转移字符,则只是被识别为普通的字符:
    比如\j,会被处理为j这个字母本身;
  • 反斜杠加g以及中括号内一个名字,即:\g,对应着命了名的组,named group

    接着上面的举例:

    想要把对应的:

    hello crifan, nihao crifan
       
    • 1
    • 1

    中的crifan提取出来,只剩:

    crifan

    就可以写成:

    inputStr = "hello crifan, nihao crifan";
    replacedStr = re.sub(r"hello (\w+), nihao \1", "\g<1>", inputStr);
    print "replacedStr=",replacedStr; #crifan
       
    • 1
    • 2
    • 3
    • 1
    • 2
    • 3

    对应的带命名的组(named group)的版本是:

    inputStr = “hello crifan, nihao crifan”;
    replacedStr = re.sub(r”hello (?P\w+), nihao (?P=name)”, “\g”, inputStr);
    print “replacedStr=”,replacedStr; #crifan

    repl是函数

    举例说明:

    比如输入内容是:

    hello 123 world 456
       
    • 1
    • 1

    想要把其中的数字部分,都加上111,变成:

    hello 234 world 567
       
    • 1
    • 1

    那么就可以写成:

    #!/usr/bin/python
    # -*- coding: utf-8 -*-
    
    import re;
    
    def pythonReSubDemo():
        """
            demo Pyton re.sub
        """
        inputStr = "hello 123 world 456";
    
        def _add111(matched):
            intStr = matched.group("number"); #123
            intValue = int(intStr);
            addedValue = intValue + 111; #234
            addedValueStr = str(addedValue);
            return addedValueStr;
    
        replacedStr = re.sub("(?P<number>\d+)", _add111, inputStr);
        print "replacedStr=",replacedStr; #hello 234 world 567
    
    ###############################################################################
    if __name__=="__main__":
        pythonReSubDemo();
       
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24

    第三个参数:string

    string,即表示要被处理,要被替换的那个string字符串。

    没什么特殊要说明。

    第四个参数:count

    举例说明:

    继续之前的例子,假如对于匹配到的内容,只处理其中一部分。

    比如对于:

    hello 123 world 456 nihao 789
       
    • 1
    • 1

    只是像要处理前面两个数字:123,456,分别给他们加111,而不处理789,

    那么就可以写成:

    #!/usr/bin/python
    # -*- coding: utf-8 -*-
    
    import re;
    
    def pythonReSubDemo():
        """
            demo Pyton re.sub
        """
        inputStr = "hello 123 world 456 nihao 789";
    
        def _add111(matched):
            intStr = matched.group("number"); #123
            intValue = int(intStr);
            addedValue = intValue + 111; #234
            addedValueStr = str(addedValue);
            return addedValueStr;
    
        replacedStr = re.sub("(?P<number>\d+)", _add111, inputStr, 2);
        print "replacedStr=",replacedStr; #hello 234 world 567 nihao 789
    
    ###############################################################################
    if __name__=="__main__":
        pythonReSubDemo();
       
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24

    第五个参数:flags

    关于re.sub的注意事项

    要注意,被替换的字符串,即参数repl,是普通的字符串,不是pattern

    注意到,语法是:

    re.sub(pattern, repl, string, count=0, flags=0)
       
    • 1
    • 1

    即,对应的第二个参数是repl。

    需要你指定对应的r前缀,才是pattern:

    r"xxxx"
       
    • 1
    • 1

    不要误把第四个参数flag的值,传递到第三个参数count中了

    否则就会出现我这里:

    【已解决】Python中,(1)re.compile后再sub可以工作,但re.sub不工作,或者是(2)re.search后replace工作,但直接re.sub以及re.compile后再re.sub都不工作

    遇到的问题:

    当传递第三个参数,原以为是flag的值是,

    结果实际上是count的值

    所以导致re.sub不功能,

    所以要参数指定清楚了:

    replacedStr = re.sub(replacePattern, orignialStr, replacedPartStr, flags=re.I); # can omit count parameter
       
    • 1
    • 1

    或:

    replacedStr = re.sub(replacePattern, orignialStr, replacedPartStr, 1, re.I); # must designate count parameter
       
    • 1
    • 1

    才可以正常工作。

<think>我们详细解析Python中的re.sub函数: 功能re.sub()用于在字符串中执行正则表达式匹配并替换匹配项。 格式:re.sub(pattern, repl, string, count=0, flags=0) 参数解析: - pattern: 正则表达式模式(字符串或已编译的正则对象) - repl: 替换内容(字符串或函数) - string: 被处理的原始字符串 - count: 最大替换次数(默认0表示全部替换) - flags: 正则标志(如re.IGNORECASE等) 替换方式: 1. 字符串替换:普通字符串或包含反向引用的字符串(如r'\1') 2. 函数替换:将匹配对象作为参数传递给函数,用函数返回值替换 反向引用语法: - 传统:\1, \2 ... 表示分组 - 命名分组:\g<name> 或 \g<1>(避免歧义) 示例1:日期格式重排 ```python import re s = '2018-06-07' result = re.sub(r'(\d{4})-(\d{2})-(\d{2})', r'\2-\3-\1', s) print(result) # 输出:06-07-2018 ``` 示例2:使用命名分组 ```python result = re.sub(r'(?P<year>\d{4})-(?P<month>\d{2})-(?P<day>\d{2})', r'\g<month>-\g<day>-\g<year>', s) ``` 示例3:函数替换(将匹配的数字乘以2) ```python def double(match): value = int(match.group(0)) return str(value * 2) s = 'A23G4HFD567' print(re.sub(r'\d+', double, s)) # 输出:A46G8HFD1134 ``` 注意事项: - 替换函数应接收一个匹配对象参数,返回字符串 - 当repl是字符串时,其中的反斜杠会被处理(如\n表示换行),因此建议使用原始字符串(前缀r) - 若模式中有分组,函数可通过match.group(index)获取 性能建议:多次使用同一模式时,预编译正则表达式(re.compile) 高级替换技巧:使用lambda表达式简化 ```python # 将所有数字加1 s = 'A1B2C3' result = re.sub(r'\d', lambda m: str(int(m.group())+1), s) # 输出:'A2B3C4' ``` 参考资料:[^2][^3][^4] §§相关问题§§ 1. re.sub如何处理分组引用?[^2] 2. 如何使用函数进行复杂的替换操作?[^4] 3. re.sub与str.replace有何区别? 4. 如何避免正则表达式中的转义问题? </think>### Python `re.sub` 命令解析 `re.sub()` 是 Python `re` 模块中用于执行正则表达式替换的核心函数,可实现复杂的字符串替换操作。 #### 基础语法 ```python re.sub(pattern, repl, string, count=0, flags=0) ``` | 参数 | 说明 | |----------|----------------------------------------------------------------------| | `pattern` | 正则表达式模式(字符串或预编译对象) | | `repl` | 替换内容(字符串或函数) | | `string` | 原始输入字符串 | | `count` | 最大替换次数(默认 `0` = 全部替换) | | `flags` | 正则标志(如 `re.IGNORECASE` 忽略大小写) | --- #### 核心功能解析 ##### 1. **字符串替换** ```python import re text = "2023-01-15" result = re.sub(r'(\d{4})-(\d{2})-(\d{2})', r'\2/\3/\1', text) # 输出:'01/15/2023' [^2] ``` - 使用反向引用 `\1`, `\2` 引用捕获组 - 命名分组引用:`\g<name>`(如 `\g<year>`) ##### 2. **函数替换(动态处理)** ```python def to_upper(match): return match.group(0).upper() text = "hello world" result = re.sub(r'\b\w+\b', to_upper, text) # 输出:'HELLO WORLD' ``` - 函数接收 `Match` 对象参数,返回替换字符串 - 常用场景:大小写转换、数值计算、条件替换 ##### 3. **Lambda 表达式简化** ```python text = "a1 b2 c3" result = re.sub(r'\d', lambda m: str(int(m.group())*2), text) # 输出:'a2 b4 c6' [^4] ``` - 匿名函数处理简单逻辑 - 避免定义独立函数 ##### 4. **特殊替换模式** ```python # 移除HTML标签 html = "<div>Hello</div>" clean = re.sub(r'<[^>]+>', '', html) # 输出:'Hello' # 规范化空格 text = "a b c" normalized = re.sub(r'\s+', ' ', text) # 输出:'a b c' ``` --- #### 关键机制 1. **匹配流程**: - 扫描字符串查找所有匹配 `pattern` 的子串 - 对每个匹配执行替换操作 - 返回新字符串(原始字符串不变) 2. **转义处理**: - 替换字符串中的 `\` 需要转义(建议使用原始字符串 `r"..."`) - 数字后接字符时需用 `\g<1>` 避免歧义: ```python re.sub(r'(\d)', r'\g<1>0', "a1b2") # 正确: 'a10b20' ``` 3. **性能优化**: - 多次使用相同模式时预编译: ```python pattern = re.compile(r'\d+') result = pattern.sub("X", "a1b2c3") # 输出:'aXbXcX' ``` --- #### 注意事项 1. **贪婪匹配**:默认贪婪模式,需用 `?` 启用非贪婪匹配(如 `.*?`) 2. **跨行匹配**:需用 `re.DOTALL` 标志使 `.` 匹配换行符 `\n` [^3] 3. **引用冲突**:替换字符串中的 `\n`、`\t` 会被解析为转义字符 4. **空匹配处理**:`pattern` 匹配空字符串时将无限递归(需避免) ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值