Python正則表達(dá)式re.sub()用法詳解
源代碼、參數(shù)及其意義:
def sub(pattern, repl, string, count=0, flags=0):
"""Return the string obtained by replacing the leftmost
non-overlapping occurrences of the pattern in string by the
replacement repl. repl can be either a string or a callable;
if a string, backslash escapes in it are processed. If it is
a callable, it's passed the Match object and must return
a replacement string to be used."""
return _compile(pattern, flags).sub(repl, string, count)從源碼中看出re.sub()函數(shù)共有5個參數(shù):
- pattern:表示正則中的模式字符串;
- repl:表示要替換的字符串(即匹配到pattern后替換為repl),也可以是個函數(shù);
- string:表示要被處理(查找替換)的原始字符串;
- count:可選參數(shù),表示要替換的最大次數(shù),而且必須是非負(fù)整數(shù),該參數(shù)默認(rèn)為0,即所有的匹配都會替換;
- flags:可選參數(shù),表示編譯時用的匹配模式(如忽略大小寫、多行模式等),數(shù)字形式,默認(rèn)為0。
re.sub():匹配替換為選擇的文本。
1.匹配單個數(shù)字或字母
示例代碼:【只匹配單一數(shù)字】
import re s = "您好,歡迎來到我的博客:https://blog.csdn.net/weixin_44799217,,,###,,,我的郵箱是:535646343@qq.com. Today is 2021/12/21. It is a wonderful DAY!" # 只匹配單一數(shù)字 ret = re.sub(r'[0-9]', "*", s) print(ret)
運(yùn)行結(jié)果:

re.sub(r'[0-9]', '*', s) 這句話表示只匹配單一數(shù)字,并將每一個數(shù)字替換為一個星號 。
示例代碼:【只匹配單一字母】
import re s = "您好,歡迎來到我的博客:https://blog.csdn.net/weixin_44799217,,,###,,,我的郵箱是:535646343@qq.com. Today is 2021/12/21. It is a wonderful DAY!" # 只匹配單一字母 ret = re.sub(r'[a-z]', "*", s) print(ret) ret = re.sub(r'[A-Z]', "*", s) print(ret) ret = re.sub(r'[a-zA-Z]', "*", s) print(ret) ret = re.sub(r'[A-z]', "*", s) print(ret)
運(yùn)行結(jié)果:

re.sub(r'[a-z]', '*', s) 表示只匹配單一小寫字母,并將每一個小寫字母替換為一個星號 。re.sub(r'[A-Z]', '*', s) 表示只匹配單一大寫字母,并將每一個大寫字母替換為一個星號 。re.sub(r'[A-Za-z]', '*', s) 這句話則表示只匹配單一字母,并將每一個字母替換為一個星號 。
示例代碼:【匹配單一數(shù)字和字母】
import re s = "您好,歡迎來到我的博客:https://blog.csdn.net/weixin_44799217,,,###,,,我的郵箱是:535646343@qq.com. Today is 2021/12/21. It is a wonderful DAY!" # 匹配單一數(shù)字和字母 ret = re.sub(r'[0-9a-z]', "*", s) print(ret) ret = re.sub(r'[0-9A-Z]', "*", s) print(ret) ret = re.sub(r'[0-9a-zA-Z]', "*", s) print(ret) ret = re.sub(r'[0-9A-z]', "*", s) print(ret)
運(yùn)行結(jié)果:

re.sub(r'[0-9A-Z]', '*', s) 表示只匹配單一數(shù)字和大寫字母,并將每一個數(shù)字和大寫字母替換為一個星號 。
re.sub(r'[0-9a-z]', '*', s) 表示只匹配單一數(shù)字和小寫字母,并將每一個數(shù)字和小寫字母替換為一個星號 。
re.sub(r'[0-9A-Za-z]', '*', s) 表示只匹配單一數(shù)字和字母,并將每一個數(shù)字和字母替換為一個星號 。
2.匹配多個數(shù)字或字母
注意:這里的所說的多個指的是大于等于一個。
示例代碼:【匹配多個數(shù)字】
import re s = "您好,歡迎來到我的博客:https://blog.csdn.net/weixin_44799217,,,###,,,我的郵箱是:535646343@qq.com. Today is 2021/12/21. It is a wonderful DAY!" # 匹配多個數(shù)字 ret = re.sub(r'[0-9]+', "*", s) print(ret)
運(yùn)行結(jié)果:

re.sub(r'[0-9]+', '*', s) 表示匹配多個連續(xù)的數(shù)字,并將多個連續(xù)的數(shù)字替換為一個星號 。
示例代碼:【匹配多個字母】
import re s = "您好,歡迎來到我的博客:https://blog.csdn.net/weixin_44799217,,,###,,,我的郵箱是:535646343@qq.com. Today is 2021/12/21. It is a wonderful DAY!" # 匹配多個字母 ret = re.sub(r'[a-z]+', "*", s) print(ret) ret = re.sub(r'[A-Z]+', "*", s) print(ret) ret = re.sub(r'[a-zA-Z]+', "*", s) print(ret)
運(yùn)行結(jié)果:

- re.sub(r'[a-z]+', '*', s) 表示匹配多個連續(xù)的小寫字母,并將多個連續(xù)的小寫字母替換為一個星號 。
- re.sub(r'[A-Z]+', '*', s) 表示匹配多個連續(xù)的大寫字母,并將多個連續(xù)的大寫字母替換為一個星號 。
- re.sub(r'[A-Za-z]+', '*', s) 表示匹配多個連續(xù)的字母,并將多個連續(xù)的字母替換為一個星號 。
示例代碼:【匹配多個連續(xù)數(shù)字和字母】
import re s = "您好,歡迎來到我的博客:https://blog.csdn.net/weixin_44799217,,,###,,,我的郵箱是:535646343@qq.com. Today is 2021/12/21. It is a wonderful DAY!" # 匹配多個數(shù)字和字母 ret = re.sub(r'[0-9a-zA-Z]+', "*", s) print(ret)
運(yùn)行結(jié)果:

re.sub(r'[0-9A-Za-z]+', '*', s) 表示匹配多個連續(xù)的數(shù)字和字母,并將多個連續(xù)的數(shù)字、連續(xù)的字母、連續(xù)的數(shù)字和字母替換為一個星號 。
3.匹配其他
示例代碼:【匹配非數(shù)字】
import re s = "您好,歡迎來到我的博客:https://blog.csdn.net/weixin_44799217,,,###,,,我的郵箱是:535646343@qq.com. Today is 2021/12/21. It is a wonderful DAY!" # 匹配非數(shù)字 ret = re.sub(r'[^0-9]', "*", s) print(ret) ret = re.sub(r'[^0-9]+', "*", s) print(ret)
運(yùn)行結(jié)果:

re.sub(r'[^0-9]', '*', s)表示匹配單個非數(shù)字,并將單個非數(shù)字替換為一個星號 。re.sub(r'[^0-9]+', '*', s)表示匹配多個連續(xù)的非數(shù)字,并將多個連續(xù)的非數(shù)字替換為一個星號 。
示例代碼:【匹配非字母】
import re s = "您好,歡迎來到我的博客:https://blog.csdn.net/weixin_44799217,,,###,,,我的郵箱是:535646343@qq.com. Today is 2021/12/21. It is a wonderful DAY!" # 匹配非字母 ret = re.sub(r'[^a-z]', "*", s) print(ret) ret = re.sub(r'[^A-Z]', "*", s) print(ret) ret = re.sub(r'[^a-zA-Z]', "*", s) print(ret) ret = re.sub(r'[^a-z]+', "*", s) print(ret) ret = re.sub(r'[^A-Z]+', "*", s) print(ret) ret = re.sub(r'[^a-zA-Z]+', "*", s) print(ret)
運(yùn)行結(jié)果:

- re.sub(r'[^a-z]', '*', s) 表示匹配單個非小寫字母,并將單個非小寫字母替換為一個星號 。
- re.sub(r'[^A-Z]', '*', s) 表示匹配單個非大寫字母,并將單個非大寫字母替換為一個星號 。
- re.sub(r'[^A-Za-z]', '*', s) 表示匹配單個非字母,并將單個非字母替換為一個星號 。
- re.sub(r'[^a-z]+', '*', s) 表示匹配多個連續(xù)的非小寫字母,并將多個連續(xù)的非小寫字母替換為一個星號 。
- re.sub(r'[^A-Z]+', '*', s) 表示匹配多個連續(xù)的非大寫字母,并將多個連續(xù)的非大寫字母替換為一個星號 。
- re.sub(r'[^A-Za-z]+', '*', s)表示匹配多個連續(xù)的非字母,并將多個連續(xù)的非字母替換為一個星號 。
示例代碼:【匹配非數(shù)字和非字母】
import re s = "您好,歡迎來到我的博客:https://blog.csdn.net/weixin_44799217,,,###,,,我的郵箱是:535646343@qq.com. Today is 2021/12/21. It is a wonderful DAY!" # 匹配非數(shù)字和非字母 ret = re.sub(r'[^0-9a-zA-Z]', "*", s) print(ret) ret = re.sub(r'[^0-9a-zA-Z]+', "*", s) print(ret)
運(yùn)行結(jié)果:

- re.sub(r'[^0-9A-Za-z]', '*', s) 表示匹配單個非數(shù)字和非字母,并將單個非數(shù)字和非字母替換為一個星號 。
- re.sub(r'[^0-9A-Za-z]+', '*', s) 表示匹配多個連續(xù)的非數(shù)字和非字母,并將多個連續(xù)的非數(shù)字和非字母替換為一個星號 。
示例代碼:【匹配固定形式】【只保留字母和空格,將 repl 設(shè)置為空字符即可】
import re s = "您好,歡迎來到我的博客:https://blog.csdn.net/weixin_44799217,,,###,,,我的郵箱是:535646343@qq.com. Today is 2021/12/21. It is a wonderful DAY!" # 匹配固定形式 ret = re.sub(r'[^a-z ]', " ", s) print(ret) ret = re.sub(r'[^a-z ]+', " ", s) print(ret) ret = re.sub(r'[^a-zA-Z ]', " ", s) print(ret) ret = re.sub(r'[^a-zA-Z ]+', " ", s) print(ret)
運(yùn)行結(jié)果:

示例代碼:【去除以 @ 開頭的英文單詞】
import re s = "您好,歡迎來到我的博客:https://blog.csdn.net/weixin_44799217,,,###,,,我的郵箱是:535646343@qq.com. Today is 2021/12/21. It is a wonderful DAY!" # 去除以 @ 開頭的英文單詞 ret = re.sub(r'@[a-zA-Z ]+', " ", s) print(ret)
運(yùn)行結(jié)果:

示例代碼:【去除原始字符串中的URL】
import re s = "您好,歡迎來到我的博客:https://blog.csdn.net/weixin_44799217,,,###,,,我的郵箱是:535646343@qq.com. Today is 2021/12/21. It is a wonderful DAY!" # d.去除原始字符串中的URL ret = re.sub(r'https[:.]+\S+', "", s) print(ret)
運(yùn)行結(jié)果:

示例代碼:【匹配到的所有空格使用“+”來替換】
import re
s = "Long live the people's Republic of China"
ret = re.sub("\s", "+", s)
print(ret)
ret2 = re.sub("\s", "+", s, 3) # 通過count參數(shù)控制替換的次數(shù)
print(ret2)運(yùn)行結(jié)果:

總結(jié)
到此這篇關(guān)于Python正則表達(dá)式re.sub()用法詳解的文章就介紹到這了,更多相關(guān)Python re.sub()用法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Pycharm創(chuàng)建Django項(xiàng)目示例實(shí)踐
本文主要介紹了Pycharm創(chuàng)建Django項(xiàng)目示例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03
python實(shí)現(xiàn)修改xml文件內(nèi)容
這篇文章主要介紹了python實(shí)現(xiàn)修改xml文件內(nèi)容,XML 指可擴(kuò)展標(biāo)記語言,是一種標(biāo)記語言,是從標(biāo)準(zhǔn)通用標(biāo)記語言(SGML)中簡化修改出來的2022-07-07
python3的一個天坑問題及解決方法:報(bào)錯UnicodeDecodeError: ‘utf-8‘
在調(diào)試程序發(fā)現(xiàn)python3的一個天坑問題:報(bào)錯UnicodeDecodeError: ‘utf-8‘ codec can‘t decode byte 0xa3 in position 59: invalid,特此曝光,為眾位開發(fā)朋友提個醒2023-09-09
詳解Python如何實(shí)現(xiàn)查看WiFi密碼
這篇文章主要為大家詳細(xì)介紹了如何使用python來試試看看能不能讀取到已連接過WIFI的密碼,文中的示例代碼講解詳細(xì),?感興趣的小伙伴可以了解下2023-11-11
Python實(shí)現(xiàn)的排列組合計(jì)算操作示例
這篇文章主要介紹了Python實(shí)現(xiàn)的排列組合計(jì)算操作,涉及Python數(shù)學(xué)運(yùn)算的相關(guān)函數(shù)與使用技巧,需要的朋友可以參考下2017-10-10

