re.sub的功能

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

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

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

举个最简单的例子:

如果输入字符串是:       
inputStr = "hello 111 world 111"

那么你可以通过     
replacedStr = inputStr.replace("111", "222")

去换成   
"hello 222 world 222"

但是,如果输入字符串是:    
inputStr = "hello 123 world 456"

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

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

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

就需要借助于re.sub,通过正则表达式,来实现这种相对复杂的字符串的替换:     
replacedStr = re.sub("\d+", "222", inputStr)

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

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

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

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

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

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

re.sub共有五个参数。

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

两个可选参数:count, flags

第一个参数:pattern

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

需要知道的是:

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

比如,想要处理:   
hello crifan, nihao crifan

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

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

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

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

第二个参数:repl

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

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

repl是字符串

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

即:

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

接着上面的举例:

想要把对应的:   
hello crifan, nihao crifan

中的crifan提取出来,只剩:   
crifan

就可以写成:

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

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

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

repl是函数

举例说明:

比如输入内容是:   
hello 123 world 456

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

那么就可以写成:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#!/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();

第三个参数:string

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

没什么特殊要说明。

第四个参数:count

举例说明:

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

比如对于:   
hello 123 world 456 nihao 789

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

那么就可以写成:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#!/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();

第五个参数:flags















本文转自UltraSQL51CTO博客,原文链接: http://blog.51cto.com/ultrasql/1704885,如需转载请自行联系原作者



详解Python中re.sub相关推荐

  1. python操作目录_详解python中的文件与目录操作

    详解python中的文件与目录操作 一 获得当前路径 1.代码1 >>>import os >>>print('Current directory is ',os. ...

  2. python open 打开是什么类型的文件-详解Python中open()函数指定文件打开方式的用法...

    文件打开方式 当我们用open()函数去打开文件的时候,有好几种打开的模式. 'r'->只读 'w'->只写,文件已存在则清空,不存在则创建. 'a'->追加,写到文件末尾 'b'- ...

  3. python中list[1啥意思_详解Python中list[::-1]的几种用法

    本文主要介绍了Python中list[::-1]的几种用法,分享给大家,具体如下: s = "abcde" list的[]中有三个参数,用冒号分割 list[param1:para ...

  4. pythonnamedtuple定义类型_详解Python中namedtuple的使用

    namedtuple是Python中存储数据类型,比较常见的数据类型还有有list和tuple数据类型.相比于list,tuple中的元素不可修改,在映射中可以当键使用. namedtuple: na ...

  5. python停止线程池_详解python中Threadpool线程池任务终止示例代码

    需求 加入我们需要处理一串个位数(0~9),奇数时需要循环打印它:偶数则等待对应时长并完成所有任务:0则是错误,但不需要终止任务,可以自定义一些处理. 关键点 定义func函数处理需求 callbac ...

  6. python join_详解Python中的join()函数的用法

    函数:string.join() Python中有join()和os.path.join()两个函数,具体作用如下: join(): 连接字符串数组.将字符串.元组.列表中的元素以指定的字符(分隔符) ...

  7. python中index函数_详解python中的index函数用法

    1.函数的创建 def fun(): #定义 print('hellow') #函数的执行代码 retrun 1 #返回值 fun() #执行函数 2.函数的参数 普通参数 :要按照顺序输入参数 de ...

  8. python中pandas安装视频教程_详解Python中pandas的安装操作说明(傻瓜版)

    很多人来问我pandas的安装(python数据分析里面的必修课) 步骤如下: 安装python的时候,把路径加到系统里,这样,随时可以用pip 路径添加方法: 查找路径: 路径1: 2.例如: 即: ...

  9. [转载] python中for语句用法_详解Python中for循环的使用_python

    参考链接: 在Python中将else条件语句与for循环一起使用 这篇文章主要介绍了Python中for循环的使用,来自于IBM官方网站技术文档,需要的朋友可以参考下 for 循环 本系列前面 &q ...

  10. python操作符op_详解python中的 is 操作符

    大家可以与Java中的 == 操作符相互印证一下,加深一下对引用和对象的理解.原问题: Python为什么直接运行和在命令行运行同样语句但结果却不同,他们的缓存机制不同吗? 其实,高票答案已经说得很详 ...

最新文章

  1. re.match()用法详解
  2. 基于C#局域网语音聊天
  3. C#架构设计-程序运行时从xml配置文件中加载配置项并设置为全局变量
  4. wxWidgets:wxWebView类用法
  5. Tomcat配置可以访问外部资源路径
  6. Python使用傅里叶变换调整音频文件音量
  7. Git服务器的搭建和使用
  8. Android实现传感器应用及位置服务
  9. VS2010开发环境之使用技巧
  10. object c中的多态
  11. Django-ftpserver 的两个坑
  12. Data Base学习记录:关系模型
  13. 抖音OAuth2.0快速登录源码
  14. Azure CDN 服务详解
  15. [Irving]SQL去重复-DISTINCT用法
  16. 如何用matlab编写分段函数_matlab 如何写分段函数
  17. 尚硅谷python入门
  18. html里的常用特殊符号表示大全
  19. 习题 9.9 商店销售某一商品,商店每天公布统一的折扣(discount)。同时允许销售人员在销售时灵活掌握售价(price),在此基础上,对一次购10件以上者,还可以享受9.8折优惠。
  20. Java基础篇——三大特性(封装)

热门文章

  1. Atitit 下推自动机﹙PDA﹚说明书 目录 1. 概念组成与原理成分 1 2. 性状 1 3. 适用场景 主治 适应症 1 3.1. 所有场景()。 1 3.2. 语法解析 构建ast 2 3.
  2. paip.python错误解决22
  3. 最懂基金经理的第三方机构猫头鹰,到底是谁?
  4. 互联网光环下的新金融群像:运营最重要的是说人话
  5. 基于弹性计算网络能力提升容器密度最佳实践
  6. 259年后,中国最大的皇家园林上云了
  7. 毕设题目:Matlab图像重建
  8. 【优化预测】基于matlab人工鱼群算法优化BP神经网络预测【含Matlab源码 523期】
  9. 【VRP】基于matlab改进的模拟退火和遗传算法求解车辆路径规划问题【含Matlab源码 343期】
  10. 【优化预测】基于matlab蝙蝠算法优化SVM预测【含Matlab源码 141期】