re.sub的使用方法

re是正则的表达式,sub是substitute表示替换

re.sub是相对复杂点的替换

举个例子:


inputs = "hello 11 word 11"

想11变成22

replacestr = inputs.replace("11","22)

但是如果是inputs = “hello 123 world 345”

想把数字都替换成222

就需要用正则替换

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 

第二个参数:repl

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

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

repl是字符串

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

即:

\n:会被处理为对应的换行符; 

\r:会被处理为回车符; 

其他不能识别的转移字符,则只是被识别为普通的字符: 

比如\j,会被处理为j这个字母本身; 

反斜杠加g以及中括号内一个名字,即:\g,对应着命了名的组,named group

第三个参数:string

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

没什么特殊要说明。

第四个参数:count

举例说明:

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

比如对于:

hello 123 world 456 nihao 789

1

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

那么就可以写成:

replacedStr = re.sub("(?P\d+)", _add111, inputStr, 2);

你可能感兴趣的:(re.sub的使用方法)