字符集是由一對方括號 “[]” 括起來的字符集合。使用字符集,可以匹配多個字符中的一個。
舉個例子,比如你使用 C[ET]O
匹配到的是 CEO 或 CTO ,也就是說 [ET]
代表的是一個 E 或者一個 T 。像上面提到的 [a-z]
,就是所有小寫字母中的其中一個,這里使用了連字符 “-” 定義一個連續(xù)字符的字符范圍。當(dāng)然,像這種寫法,里面可以包含多個字符范圍的,比如:[0-9a-fA-F]
,匹配單個的十六進(jìn)制數(shù)字,且不分大小寫。注意了,字符和范圍定義的先后順序?qū)ζヅ涞慕Y(jié)果是沒有任何影響的。
其實(shí)說了那么多,只是想證明,字符集一對方括號 “[]” 里面的字符關(guān)系是"或(OR)"關(guān)系,下面看一個例子:
import re
a = 'uav,ubv,ucv,uwv,uzv,ucv,uov'
# 字符集
# 取 u 和 v 中間是 a 或 b 或 c 的字符
findall = re.findall('u[abc]v', a)
print(findall)
# 如果是連續(xù)的字母,數(shù)字可以使用 - 來代替
l = re.findall('u[a-c]v', a)
print(l)
# 取 u 和 v 中間不是 a 或 b 或 c 的字符
re_findall = re.findall('u[^abc]v', a)
print(re_findall)
輸出的結(jié)果:
['uav', 'ubv', 'ucv', 'ucv']
['uav', 'ubv', 'ucv', 'ucv']
['uwv', 'uzv', 'uov']
在例子中,使用了取反字符集,也就是在左方括號 “[” 后面緊跟一個尖括號 “^”,就會對字符集取反。需要記住的一點(diǎn)是,取反字符集必須要匹配一個字符。比如:q[^u]
并不意味著:匹配一個 q,后面沒有 u 跟著。它意味著:匹配一個 q,后面跟著一個不是 u 的字符。具體可以對比上面例子中輸出的結(jié)果來理解。
我們都知道,正則表達(dá)式本身就定義了一些規(guī)則,比如 \d
,匹配所有數(shù)字字符,其實(shí)它是等價于 [0-9],下面也寫了個例子,通過字符集的形式解釋了這些特殊字符。
import re
a = 'uav_ubv_ucv_uwv_uzv_ucv_uov&123-456-789'
# 概括字符集
# \d 相當(dāng)于 [0-9] ,匹配所有數(shù)字字符
# \D 相當(dāng)于 [^0-9] , 匹配所有非數(shù)字字符
findall1 = re.findall('\d', a)
findall2 = re.findall('[0-9]', a)
findall3 = re.findall('\D', a)
findall4 = re.findall('[^0-9]', a)
print(findall1)
print(findall2)
print(findall3)
print(findall4)
# \w 匹配包括下劃線的任何單詞字符,等價于 [A-Za-z0-9_]
findall5 = re.findall('\w', a)
findall6 = re.findall('[A-Za-z0-9_]', a)
print(findall5)
print(findall6)
輸出結(jié)果:
['1', '2', '3', '4', '5', '6', '7', '8', '9']
['1', '2', '3', '4', '5', '6', '7', '8', '9']
['u', 'a', 'v', '_', 'u', 'b', 'v', '_', 'u', 'c', 'v', '_', 'u', 'w', 'v', '_', 'u', 'z', 'v', '_', 'u', 'c', 'v', '_', 'u', 'o', 'v', '&', '-', '-']
['u', 'a', 'v', '_', 'u', 'b', 'v', '_', 'u', 'c', 'v', '_', 'u', 'w', 'v', '_', 'u', 'z', 'v', '_', 'u', 'c', 'v', '_', 'u', 'o', 'v', '&', '-', '-']
['u', 'a', 'v', '_', 'u', 'b', 'v', '_', 'u', 'c', 'v', '_', 'u', 'w', 'v', '_', 'u', 'z', 'v', '_', 'u', 'c', 'v', '_', 'u', 'o', 'v', '1', '2', '3', '4', '5', '6', '7', '8', '9']
['u', 'a', 'v', '_', 'u', 'b', 'v', '_', 'u', 'c', 'v', '_', 'u', 'w', 'v', '_', 'u', 'z', 'v', '_',
審核編輯:符乾江
-
python
+關(guān)注
關(guān)注
56文章
4827瀏覽量
86761 -
正則表達(dá)式
+關(guān)注
關(guān)注
0文章
28瀏覽量
3690
發(fā)布評論請先 登錄
labview如何使用VISA串口資源查找的正則表達(dá)式提取串口的資源名稱?
基礎(chǔ)篇3:掌握Python中的條件語句與循環(huán)
干貨分享 | 零基礎(chǔ)上手!TSMaster圖形信號表達(dá)式實(shí)操指南

Linux中文本處理命令的用法

Linux grep命令詳解
詳解nginx中的正則表達(dá)式

4G模組LuatOS開發(fā)|iconv字符集轉(zhuǎn)換技術(shù)篇

Verilog表達(dá)式的位寬確定規(guī)則

通過工業(yè)智能網(wǎng)關(guān)實(shí)現(xiàn)中間變量表達(dá)式的快速配置

nginx中的正則表達(dá)式和location路徑匹配指南

TestStand表達(dá)式中常用的語法規(guī)則和運(yùn)算符使用

Java表達(dá)式引擎選型調(diào)研分析

評論