字符集
好了,通過上面的幾個(gè)實(shí)例我們初步認(rèn)識(shí)了 Python 的正則表達(dá)式,可能你就會(huì)問,正則表達(dá)式還有什么規(guī)則,什么字母代表什么意思呢?
其實(shí),這些都不急,在本章后面會(huì)給出對(duì)應(yīng)的正則表達(dá)式規(guī)則列表,而且這些東西在網(wǎng)上隨便都能 Google 到。所以現(xiàn)在,我們還是進(jìn)一步加深對(duì)正則表達(dá)式的理解,講一下正則表達(dá)式的字符集。
字符集是由一對(duì)方括號(hào) “[]” 括起來的字符集合。使用字符集,可以匹配多個(gè)字符中的一個(gè)。
舉個(gè)例子,比如你使用 C[ET]O 匹配到的是 CEO 或 CTO ,也就是說 [ET] 代表的是一個(gè) E 或者一個(gè) T 。像上面提到的 [a-z] ,就是所有小寫字母中的其中一個(gè),這里使用了連字符 “-” 定義一個(gè)連續(xù)字符的字符范圍。當(dāng)然,像這種寫法,里面可以包含多個(gè)字符范圍的,比如:[0-9a-fA-F] ,匹配單個(gè)的十六進(jìn)制數(shù)字,且不分大小寫。注意了,字符和范圍定義的先后順序?qū)ζヅ涞慕Y(jié)果是沒有任何影響的。
其實(shí)說了那么多,只是想證明,字符集一對(duì)方括號(hào) “[]” 里面的字符關(guān)系是或關(guān)系,下面看一個(gè)例子:
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']
在例子中,使用了取反字符集,也就是在左方括號(hào) “[” 后面緊跟一個(gè)尖括號(hào) “^”,就會(huì)對(duì)字符集取反。需要記住的一點(diǎn)是,取反字符集必須要匹配一個(gè)字符。比如:q[^u] 并不意味著:匹配一個(gè) q,后面沒有 u 跟著。它意味著:匹配一個(gè) q,后面跟著一個(gè)不是 u 的字符。具體可以對(duì)比上面例子中輸出的結(jié)果來理解。
我們都知道,正則表達(dá)式本身就定義了一些規(guī)則,比如 d,匹配所有數(shù)字字符,其實(shí)它是等價(jià)于 [0-9],下面也寫了個(gè)例子,通過字符集的形式解釋了這些特殊字符。
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 匹配包括下劃線的任何單詞字符,等價(jià)于 [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', '_', 'u', 'c', 'v', '_