python3 正則表達式學習筆記(21)

'''
re 模塊使 Python 語言擁有全部的正則表達式功能。
compile 函數根據一個模式字符串和可選的標誌參數生成一個正則表達式對象。該對象擁有一系列方法用於正則表達式匹配和替換。
re 模塊也提供了與這些方法功能完全一致的函數,這些函數使用一個模式字符串做爲它們的第一個參數。

re.match函數
re.match 嘗試從字符串的起始位置匹配一個模式,如果不是起始位置匹配成功的話,match()就返回none。
使用方法:
匹配成功re.match方法返回一個匹配的對象,否則返回None。
re.match(pattern, string, flags=0)
pattern	匹配的正則表達式
string	要匹配的字符串。
flags	標誌位,用於控制正則表達式的匹配方式,如:是否區分大小寫,多行匹配等等
'''

import re

str="123abd"
print(re.match('12',str))
print(re.match('ab',str)) #None 不在第一個

'''
group(num=0)	匹配的整個表達式的字符串,group() 可以一次輸入多個組號,在這種情況下它將返回一個包含那些組所對應值的元組。
groups()	返回一個包含所有小組字符串的元組,從 1 到 所含的小組號。
'''

line = "GuiYang is the capital of GuiZhou"
# .* 表示任意匹配除換行符(\n、\r)之外的任何單個或多個字符
matchObj = re.match(r'(.*) is (.*?) .*', line, re.M | re.I)

if matchObj:
    print("matchObj.group() : ", matchObj.group())
    print("matchObj.group(1) : ", matchObj.group(1))
    print("matchObj.group(2) : ", matchObj.group(2))
else:
    print("No match!!")

'''
re.search方法
re.search 掃描整個字符串並返回第一個成功的匹配。
函數語法:
re.search(pattern, string, flags=0)
pattern	匹配的正則表達式
string	要匹配的字符串。
flags	標誌位,用於控制正則表達式的匹配方式,如:是否區分大小寫,多行匹配等等
匹配成功re.search方法返回一個匹配的對象,否則返回None。

group(num=0)	匹配的整個表達式的字符串,group() 可以一次輸入多個組號,在這種情況下它將返回一個包含那些組所對應值的元組。
groups()	返回一個包含所有小組字符串的元組,從 1 到 所含的小組號。
'''

print(re.search("abc","abc123"))
print(re.search("123","abc123"))



'''
re.match與re.search的區別
re.match 只匹配字符串的開始,如果字符串開始不符合正則表達式,則匹配失敗,函數返回 None,而 re.search 匹配整個字符串,直到找到一個匹配。
'''



'''
檢索和替換
Python 的re模塊提供了re.sub用於替換字符串中的匹配項。
語法:
re.sub(pattern, repl, string, count=0, flags=0)
參數:
pattern : 正則中的模式字符串。
repl : 替換的字符串,也可爲一個函數。
string : 要被查找替換的原始字符串。
count : 模式匹配後替換的最大次數,默認 0 表示替換所有的匹配。
flags : 編譯時用的匹配模式,數字形式。
前三個爲必選參數,後兩個爲可選參數。
'''

print(re.sub("ac",'12',"dfacbdga"))#df12bdga


'''
compile 函數
compile 函數用於編譯正則表達式,生成一個正則表達式( Pattern )對象,供 match() 和 search() 這兩個函數使用。
語法格式爲:
re.compile(pattern[, flags])
參數:
pattern : 一個字符串形式的正則表達式
flags 可選,表示匹配模式,比如忽略大小寫,多行模式等,具體參數爲:
re.I 忽略大小寫
re.L 表示特殊字符集 \w, \W, \b, \B, \s, \S 依賴於當前環境
re.M 多行模式
re.S 即爲' . '並且包括換行符在內的任意字符(' . '不包括換行符)
re.U 表示特殊字符集 \w, \W, \b, \B, \d, \D, \s, \S 依賴於 Unicode 字符屬性數據庫
re.X 爲了增加可讀性,忽略空格和' # '後面的註釋

當匹配成功時返回一個 Match 對象,其中:
group([group1, …]) 方法用於獲得一個或多個分組匹配的字符串,當要獲得整個匹配的子串時,可直接使用 group() 或 group(0);
start([group]) 方法用於獲取分組匹配的子串在整個字符串中的起始位置(子串第一個字符的索引),參數默認值爲 0;
end([group]) 方法用於獲取分組匹配的子串在整個字符串中的結束位置(子串最後一個字符的索引+1),參數默認值爲 0;
span([group]) 方法返回 (start(group), end(group))。
'''

pattern=re.compile("[a-z]",re.I)
m=pattern.search('Hello')
print(m.span())


'''
findall
在字符串中找到正則表達式所匹配的所有子串,並返回一個列表,如果沒有找到匹配的,則返回空列表。
注意: match 和 search 是匹配一次 findall 匹配所有。
語法格式爲:
re.findall(string[, pos[, endpos]])
參數:
string 待匹配的字符串。
pos 可選參數,指定字符串的起始位置,默認爲 0。
endpos 可選參數,指定字符串的結束位置,默認爲字符串的長度。
'''

par=re.compile(r'\d')
res=par.findall('fgf45hklj67898bnmb211')
print(res)



'''
re.finditer
和 findall 類似,在字符串中找到正則表達式所匹配的所有子串,並把它們作爲一個迭代器返回。
re.finditer(pattern, string, flags=0)

pattern	匹配的正則表達式
string	要匹配的字符串。
flags	標誌位,用於控制正則表達式的匹配方式,如:是否區分大小寫,多行匹配等等
'''

it = re.finditer(r"\d+","12a32bc43jf3")
for match in it:
    print (match.group() )

'''
re.split
split 方法按照能夠匹配的子串將字符串分割後返回列表,它的使用形式如下:
re.split(pattern, string[, maxsplit=0, flags=0])
pattern	匹配的正則表達式
string	要匹配的字符串。
maxsplit	分隔次數,maxsplit=1 分隔一次,默認爲 0,不限制次數。
flags	標誌位,用於控制正則表達式的匹配方式,如:是否區分大小寫,多行匹配等等
'''

array=re.split('@','dfgf@565@fg')
print(array)


'''
正則表達式對象
re.RegexObject
re.compile() 返回 RegexObject 對象。
re.MatchObject
group() 返回被 RE 匹配的字符串。
start() 返回匹配開始的位置
end() 返回匹配結束的位置
span() 返回一個元組包含匹配 (開始,結束) 的位置
正則表達式修飾符 - 可選標誌
正則表達式可以包含一些可選標誌修飾符來控制匹配的模式。修飾符被指定爲一個可選的標誌。多個標誌可以通過按位 OR(|) 它們來指定。如 re.I | re.M 被設置成 I 和 M 標誌:

re.I	使匹配對大小寫不敏感
re.L	做本地化識別(locale-aware)匹配
re.M	多行匹配,影響 ^ 和 $
re.S	使 . 匹配包括換行在內的所有字符
re.U	根據Unicode字符集解析字符。這個標誌影響 \w, \W, \b, \B.
re.X	該標誌通過給予你更靈活的格式以便你將正則表達式寫得更易於理解。
'''

'''
^	匹配字符串的開頭
$	匹配字符串的末尾。
.	匹配任意字符,除了換行符,當re.DOTALL標記被指定時,則可以匹配包括換行符的任意字符。
[...]	用來表示一組字符,單獨列出:[amk] 匹配 'a','m'或'k'
[^...]	不在[]中的字符:[^abc] 匹配除了a,b,c之外的字符。
re*	匹配0個或多個的表達式。
re+	匹配1個或多個的表達式。
re?	匹配0個或1個由前面的正則表達式定義的片段,非貪婪方式
re{ n}	匹配n個前面表達式。例如,"o{2}"不能匹配"Bob"中的"o",但是能匹配"food"中的兩個o。
re{ n,}	精確匹配n個前面表達式。例如,"o{2,}"不能匹配"Bob"中的"o",但能匹配"foooood"中的所有o。"o{1,}"等價於"o+"。"o{0,}"則等價於"o*"。
re{ n, m}	匹配 n 到 m 次由前面的正則表達式定義的片段,貪婪方式
a| b	匹配a或b
(re)	匹配括號內的表達式,也表示一個組
(?imx)	正則表達式包含三種可選標誌:i, m, 或 x 。隻影響括號中的區域。
(?-imx)	正則表達式關閉 i, m, 或 x 可選標誌。隻影響括號中的區域。
(?: re)	類似 (...), 但是不表示一個組
(?imx: re)	在括號中使用i, m, 或 x 可選標誌
(?-imx: re)	在括號中不使用i, m, 或 x 可選標誌
(?#...)	註釋.
(?= re)	前向肯定界定符。如果所含正則表達式,以 ... 表示,在當前位置成功匹配時成功,否則失敗。但一旦所含表達式已經嘗試,匹配引擎根本沒有提高;模式的剩餘部分還要嘗試界定符的右邊。
(?! re)	前向否定界定符。與肯定界定符相反;當所含表達式不能在字符串當前位置匹配時成功。
(?> re)	匹配的獨立模式,省去回溯。
\w	匹配數字字母下劃線
\W	匹配非數字字母下劃線
\s	匹配任意空白字符,等價於 [\t\n\r\f]。
\S	匹配任意非空字符
\d	匹配任意數字,等價於 [0-9]。
\D	匹配任意非數字
\A	匹配字符串開始
\Z	匹配字符串結束,如果是存在換行,只匹配到換行前的結束字符串。
\z	匹配字符串結束
\G	匹配最後匹配完成的位置。
\b	匹配一個單詞邊界,也就是指單詞和空格間的位置。例如, 'er\b' 可以匹配"never" 中的 'er',但不能匹配 "verb" 中的 'er'。
\B	匹配非單詞邊界。'er\B' 能匹配 "verb" 中的 'er',但不能匹配 "never" 中的 'er'。
\n, \t, 等。	匹配一個換行符。匹配一個製表符, 等
\1...\9	匹配第n個分組的內容。
\10	匹配第n個分組的內容,如果它經匹配。否則指的是八進制字符碼的表達式。

實例:
[Pp]ython	匹配 "Python" 或 "python"
rub[ye]	匹配 "ruby" 或 "rube"
[aeiou]	匹配中括號內的任意一個字母
[0-9]	匹配任何數字。類似於 [0123456789]
[a-z]	匹配任何小寫字母
[A-Z]	匹配任何大寫字母
[a-zA-Z0-9]	匹配任何字母及數字
[^aeiou]	除了aeiou字母以外的所有字符
[^0-9]	匹配除了數字外的字符

\d	匹配一個數字字符。等價於 [0-9]。
\D	匹配一個非數字字符。等價於 [^0-9]。
\s	匹配任何空白字符,包括空格、製表符、換頁符等等。等價於 [ \f\n\r\t\v]。
\S	匹配任何非空白字符。等價於 [^ \f\n\r\t\v]。
\w	匹配包括下劃線的任何單詞字符。等價於'[A-Za-z0-9_]'。
\W	匹配任何非單詞字符。等價於 '[^A-Za-z0-9_]'。
'''

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章