網(wǎng)站首頁 編程語言 正文
元字符?:
預(yù)定義字符集:
我進(jìn)行組合一些復(fù)雜的正則表達(dá)式的時候是為了快捷去晚上找一些現(xiàn)成的模式,然后再自己進(jìn)行修改,變成符合自己需要的一些正則表達(dá)式。
import re
# 正則表達(dá)式中的一些使用的符號
# 匹配出現(xiàn)符合條件的 0 次的或者是 多次
str1 = 'qwertyuio1ui3oo467j398k'
# 關(guān)鍵詞: * 下面的句子就是進(jìn)行匹配 零次 或者是 多次(多個字符) 符合是數(shù)字的意思
pattern = re.compile(r'\d*')
res = re.findall(pattern, str1)
print(res)
""""
顯示的結(jié)果:
['', '', '', '', '', '', '', '', '', '1', '', '', '3', '', '', '467', '', '398', '', '']
"""
# 關(guān)鍵詞: + 匹配一次或者是多次的結(jié)果
pattern = re.compile(r'\d+')
res = re.findall(pattern, str1)
print(res)
"""
顯示結(jié)果:
['1', '3', '467', '398']
"""
# 關(guān)鍵詞: ? 匹配0次或者是1次的結(jié)果
pattern = re.compile(r'\d?')
res = re.findall(pattern, str1)
print(res)
"""
['', '', '', '', '', '', '', '', '', '1',
'', '', '3', '', '', '4', '6', '7', '',
'3', '9', '8', '', '']
"""
# {m}精確匹配m次 (比如寫進(jìn)去的3,那么他就是匹配到是3個數(shù)字字符串的所有小字符串)
pattern = re.compile(r'\d{3}')
res = re.findall(pattern, str1)
print(res)
# 結(jié)果:['467', '398']
# {m, n} 最少匹配m次,最多匹配n次
# 記住在{}里面是不能隨便加上空格的?
pattern = re.compile(r'\d{1,3}')
res = re.findall(pattern, str1)
print(res)
# 結(jié)果:['1', '3', '467', '398']
match()函數(shù)只檢測 目標(biāo)字符(串) 是不是在string的開始位置匹配,search()會掃描整個string查找匹配, match()只有在0位置匹配成功才會有返回,如果不是開始位置匹配成功,match()就會返回None
代碼解釋:
import re
m = re.match('lsp','hhttlsp')
if m is not None:?
????????print(m.group())
else:
????????print('noneFine')
顯示結(jié)果:
noneFine
n = re.search('lsp','hhttlsp')
if n is not None:
????????print(n.group())
else:
????????print(noneFine')
顯示結(jié)果:
lsp
import re
n = re.search('lsp','hhttlsp')
if n:
print(n.group())
else:
print('noneFine')
# 顯示結(jié)果:
# lsp
m = re.match('lsp','hhttlsp')
if m:
print(m.group())
else:
print('noneFine')
# 顯示結(jié)果:
# noneFine
python的re庫有兩個函數(shù)/方法用于實現(xiàn)搜索和替換功能:?sub()和subn().兩者幾乎一樣,都是將某字符串中所有匹配正則表達(dá)式的部分進(jìn)行某種形式的替換.用來替換的部分通常是一個字符串,但它也可能是一個函數(shù),該函數(shù)返回一個用來替換的字符串.subn()和 sub()一樣,但subn()還返回一個表示替換的總數(shù),替換后的字符串和表示替換總數(shù)的數(shù)字一起作為一個擁有兩個元素的元組返回.
# 可以使用sub()方法來進(jìn)行查詢和替換,sub方法的格式為:
# sub(replacement, string[, count=0])
# replacement是被替換成的文本
# string是需要被替換的文本
# count是一個可選參數(shù),指最大被替換的數(shù)量
# 下面進(jìn)行將所有的數(shù)字給進(jìn)行替換掉
pattern = re.compile(r'\d')
res = re.sub(pattern, '替換掉的數(shù)字 ',str1)
print(res)
# 下文結(jié)果,為了方便大家看到換了多少個數(shù)字,我使用了換行將字符串給換行看出有幾次換了數(shù)字
"""
qwertyuio替換掉的數(shù)字
ui替換掉的數(shù)字
oo替換掉的數(shù)字
替換掉的數(shù)字
替換掉的數(shù)字
j替換掉的數(shù)字
替換掉的數(shù)字
替換掉的數(shù)字 k
"""
# 加上顯示修改了多少次
res = re.subn(pattern, '替換掉的數(shù)字 ',str1)
print(res)
"""
結(jié)果:
('qwertyuio替換掉的數(shù)字
ui替換掉的數(shù)字
oo替換掉的數(shù)字
替換掉的數(shù)字
替換掉的數(shù)字
j替換掉的數(shù)字
替換掉的數(shù)字
替換掉的數(shù)字
k', 8)
"""
re.split(pattern,?string,?maxsplit=0,?flags=0),如果匹配成功,則返回一個列表,否則返回原string列表;
- 第1個參數(shù):正則表達(dá)式
- 第2個參數(shù):要匹配查找的原始字符串;
- 第3個參數(shù):可選參數(shù),表示最大的拆分次數(shù),默認(rèn)為0,表示全部分割;
- 第4個參數(shù):可選參數(shù),標(biāo)志位,用于控制正則表達(dá)式的匹配方式,如:是否區(qū)分大小寫,多行匹配等等;
特別注意: 此方法并不是完全匹配。它僅僅決定在字符串開始的位置是否匹配。所以當(dāng)pattern結(jié)束時若還有剩余字符,仍然成功。若想進(jìn)行完全匹配,可以在表達(dá)式末尾加上邊界匹配符'$'
str2 = '自然語言處理123機(jī)器學(xué)習(xí)456深度學(xué)習(xí)'
pattern = re.compile(r'\d+')
res = re.split(pattern, str2)
print(res)
# 結(jié)果:
# ['自然語言處理', '機(jī)器學(xué)習(xí)', '深度學(xué)習(xí)']
Python的re模塊是第一個提出解決方案的模塊:命名捕獲組和命名后向引用。(?P <name> group)將組的匹配捕獲到后向引用“名稱”中。
str2 = '自然語言處理123機(jī)器學(xué)習(xí)456深度學(xué)習(xí)'
pattern = re.compile(r'(?P<dota>\d+)(?P<lsp>\D+)')
m = re.search(pattern, str2)
print(m.group('lsp'))
# 結(jié)果為:
# 機(jī)器學(xué)習(xí)
str2 = '自然語言處理123機(jī)器學(xué)習(xí)456深度學(xué)習(xí)'
pattern = re.compile(r'(?P<dota>\d+)(?P<lsp>\D+)')
m = re.search(pattern, str2)
print(m.group('dota'))
# 結(jié)果為:
# 123
進(jìn)行號碼的篩選,小嘗試:
# 篩選號碼
str3 = 'number 132-3209-*******'
pattern = re.compile(r'(\d\d\d-\d\d)')
res = re.search(pattern, str3)
print(res.group())
# 顯示結(jié)果:
# 132-32
全部代碼:
# -*- coding:utf-8 -*-
# @Author : DaFuChen
# @File : demo1.py
# @software: PyCharm
import re
# 正則表達(dá)式中的一些使用的符號
# 匹配出現(xiàn)符合條件的 0 次的或者是 多次
str1 = 'qwertyuio1ui3oo467j398k'
# 關(guān)鍵詞: * 下面的句子就是進(jìn)行匹配 零次 或者是 多次(多個字符) 符合是數(shù)字的意思
pattern = re.compile(r'\d*')
res = re.findall(pattern, str1)
print(res)
""""
顯示的結(jié)果:
['', '', '', '', '', '', '', '', '', '1', '', '', '3', '', '', '467', '', '398', '', '']
"""
# 關(guān)鍵詞: + 匹配一次或者是多次的結(jié)果
pattern = re.compile(r'\d+')
res = re.findall(pattern, str1)
print(res)
"""
顯示結(jié)果:
['1', '3', '467', '398']
"""
# 關(guān)鍵詞: ? 匹配0次或者是1次的結(jié)果
pattern = re.compile(r'\d?')
res = re.findall(pattern, str1)
print(res)
"""
['', '', '', '', '', '', '', '', '', '1',
'', '', '3', '', '', '4', '6', '7', '',
'3', '9', '8', '', '']
"""
# {m}精確匹配m次 (比如寫進(jìn)去的3,那么他就是匹配到是3個數(shù)字字符串的所有小字符串)
pattern = re.compile(r'\d{3}')
res = re.findall(pattern, str1)
print(res)
# 結(jié)果:['467', '398']
# {m, n} 最少匹配m次,最多匹配n次
# 記住在{}里面是不能隨便加上空格的?
pattern = re.compile(r'\d{1,3}')
res = re.findall(pattern, str1)
print(res)
# 結(jié)果:['1', '3', '467', '398']
import re
n = re.search('lsp','hhttlsp')
if n:
print(n.group())
else:
print('noneFine')
# 顯示結(jié)果:
# lsp
m = re.match('lsp','hhttlsp')
if m:
print(m.group())
else:
print('noneFine')
# 顯示結(jié)果:
# noneFine
# 可以使用sub()方法來進(jìn)行查詢和替換,sub方法的格式為:
# sub(replacement, string[, count=0])
# replacement是被替換成的文本
# string是需要被替換的文本
# count是一個可選參數(shù),指最大被替換的數(shù)量
# 下面進(jìn)行將所有的數(shù)字給進(jìn)行替換掉
pattern = re.compile(r'\d')
res = re.sub(pattern, '替換掉的數(shù)字 ',str1)
print(res)
# 下文結(jié)果,為了方便大家看到換了多少個數(shù)字,我使用了換行將字符串給換行看出有幾次換了數(shù)字
"""
qwertyuio替換掉的數(shù)字
ui替換掉的數(shù)字
oo替換掉的數(shù)字
替換掉的數(shù)字
替換掉的數(shù)字
j替換掉的數(shù)字
替換掉的數(shù)字
替換掉的數(shù)字 k
"""
# 加上顯示修改了多少次
res = re.subn(pattern, '替換掉的數(shù)字 ',str1)
print(res)
"""
結(jié)果:
('qwertyuio替換掉的數(shù)字
ui替換掉的數(shù)字
oo替換掉的數(shù)字
替換掉的數(shù)字
替換掉的數(shù)字
j替換掉的數(shù)字
替換掉的數(shù)字
替換掉的數(shù)字
k', 8)
"""
str2 = '自然語言處理123機(jī)器學(xué)習(xí)456深度學(xué)習(xí)'
pattern = re.compile(r'\d+')
res = re.split(pattern, str2)
print(res)
# 結(jié)果:
# ['自然語言處理', '機(jī)器學(xué)習(xí)', '深度學(xué)習(xí)']
str2 = '自然語言處理123機(jī)器學(xué)習(xí)456深度學(xué)習(xí)'
pattern = re.compile(r'(?P<dota>\d+)(?P<lsp>\D+)')
m = re.search(pattern, str2)
print(m.group('dota'))
# 結(jié)果為:
# 123
# 篩選號碼
str3 = 'number 132-3209-*******'
pattern = re.compile(r'(\d\d\d-\d\d)')
res = re.search(pattern, str3)
print(res.group())
# 顯示結(jié)果:
# 132-32
原文鏈接:https://blog.csdn.net/blockshowtouse/article/details/126573110
相關(guān)推薦
- 2022-07-27 C++中this指針理解及作用_C 語言
- 2022-11-29 C#中泛型容器Stack<T>的用法并實現(xiàn)”撤銷/重做”功能_C#教程
- 2022-12-01 Go語言中基本數(shù)據(jù)類型的相互轉(zhuǎn)換詳解_Golang
- 2022-08-20 python使用tkinter模塊實現(xiàn)文件選擇功能_python
- 2022-02-14 flutter封裝自定義打印信息
- 2022-07-13 Python字符串中如何去除數(shù)字之間的逗號_python
- 2022-07-14 React?Native?Popup實現(xiàn)示例_React
- 2023-01-07 C++中function的實現(xiàn)原理詳解_C 語言
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支