您好,登錄后才能下訂單哦!
怎么在python中使用正則表達式提取特殊信息?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
1、刪除字符串中的 Python注釋
案例:
import re time = "2020-01-01 # 這是一個日期" num = re.sub(r'#.*$', "", time)#以#為分隔,去掉后面的信息 print("這個時間是:", num)
結果:
這個時間是: 2020-01-01
2、截取某符號前后的內容
案例1:
txt = '我的電話是:131-246-XXX19' a = txt.split(':')[0]#0表示符號前 b = txt.split(':')[1]#[-1]和[1]結果一樣,表示符號后面 print ("a的結果是:",a) print ("b的結果是:",b)
結果:
a的結果是: 我的電話是 b的結果是: 131-246-XXX19
案例2:
txt = "I love python . 我熱愛python" text = re.sub(r'\..*$', "", txt)#以.為分隔,\為轉義字符,與后面的.區分開 print("這個截取結果是:", text)
結果:
這個截取結果是: I love python
3、刪除非數字的字符串
案例:
import re time = "2020-01-01 # 這是一個日期" num = re.sub(r'\D', "", time) print("這個時間是:", num)
結果:
這個時間是: 20200101
4、只保留中文
案例:
reg = "[^\u4e00-\u9fa5]" text = "好吧!E我aa們$$開始34學習--python吧!" print(re.sub(reg, '', text))
結果:
好吧我們開始學習吧
5、只保留中文、大小寫字母和阿拉伯數字
案例:
reg = "[^0-9A-Za-z\u4e00-\u9fa5]" text = "好吧!E我aa們$$開始34學習--python吧!" print(re.sub(reg, '', text))
結果:
好吧E我aa們開始34學習python吧
6、去掉大小寫字母和數字
案例:
import re txt="Ayouleyang阿~優樂-揚" text = re.sub('[a-zA-Z0-9]','',txt) print(text)
結果:
阿~優樂-揚 1
7、去掉某個特殊字符
案列:
import re txt = '阿*a#優$樂. :揚 ;:youle+' text = re.sub('[,;;youle: :.;,$*#]+', "", txt)#[]中的符號都會被替換,類似于replace() print(text)
結果:
阿a優樂揚+ 1
8、保留英文,數字和特殊符號
案例:
reg = "[^0-9A-Za-z\u4e00-]"#只保留英文,數字和-,u4e00“-”是需要保留的符號 txt = "好吧!我的號碼是131-246-XXX19!::" text = re.sub(reg, '', txt) print(text)
結果:
131-246-XXX19
看完上述內容,你們掌握怎么在python中使用正則表達式提取特殊信息的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。