image.png
# 正則匹配
import re
# \w與\W 字母數(shù)字下劃線
print(re.findall('\w', 'hello derek \n 123'))
print(re.findall('\W', 'hello derek \n 123'))
# ['h', 'e', 'l', 'l', 'o', 'd', 'e', 'r', 'e', 'k', '1', '2', '3']
# [' ', ' ', '\n', ' ']
# \s與\S 匹配任意空白字符
print(re.findall('\s', 'hello egon 123')) # [' ', ' ', ' ', ' ']
print(re.findall('\S', 'hello egon 123')) # ['h', 'e', 'l', 'l', 'o', 'e', 'g', 'o', 'n', '1', '2', '3']
# \n \t都是空,都可以被\s匹配
print(re.findall('\s', 'hello \n egon \t 123')) # [' ', '\n', ' ', ' ', '\t', ' ']
# \n與\t
print(re.findall(r'\n', 'hello egon \n123')) # ['\n']
print(re.findall(r'\t', 'hello egon\t123')) # ['\n']
# \d與\D
print(re.findall('\d', 'hello egon 123')) # ['1', '2', '3']
print(re.findall('\D', 'hello egon 123')) # ['h', 'e', 'l', 'l', 'o', ' ', 'e', 'g', 'o', 'n', ' ']
# \A與\Z \A 匹配字符串開(kāi)始 \Z 匹配字符串結(jié)束
print(re.findall('\Ahe', 'hello egon 123')) # ['he'],\A==>^
print(re.findall('123\Z', 'hello egon 123')) # ['he'],\Z==>$
# ^與$
print(re.findall('^h', 'hello egon 123')) # ['h']
print(re.findall('3$', 'hello egon 123')) # ['3']
# 重復(fù)匹配:| . | * | ? | .* | .*? | + | {n,m} |
# . 匹配任意字符,除了換行符突照,除非re.DOTALL標(biāo)記
print(re.findall('a.b', 'a1b')) # ['a1b']
# a和b中間匹配任意一個(gè)字符
print(re.findall('a.b', 'a1b a*b a b aaab')) # ['a1b', 'a*b', 'a b', 'aab']
print(re.findall('a.b', 'a\nb')) # []
print(re.findall('a.b', 'a\nb', re.S)) # ['a\nb']
print(re.findall('a.b', 'a\nb', re.DOTALL)) # ['a\nb']同上一條意思一樣
print(re.findall('a...b', 'a123b')) # ['a123b']
# *匹配*號(hào)前的字符0次或多次
print(re.findall('ab*', 'bbbbbbb')) # []
print(re.findall('ab*', 'a')) # ['a']
print(re.findall('ab*', 'abbbb')) # ['abbbb']
print(re.findall('ab*', 'abababbabbbb')) # ['ab', 'ab', 'abb', 'abbbb']
# ? 匹配前一個(gè)字符1次或0次
print(re.findall('ab?', 'a')) # ['a']
print(re.findall('ab?', 'abbb')) # ['ab']
# 匹配所有包含小數(shù)在內(nèi)的數(shù)字
print(re.findall('\d+\.?\d*', "asdfasdf123as1.13dfa12adsf1asdf3")) # ['123', '1.13', '12', '1', '3']
# .*默認(rèn)為貪婪匹配
print(re.findall('a.*b', 'a1b22222222b')) # ['a1b22222222b']
# .*?為非貪婪匹配:推薦使用
print(re.findall('a.*?b', 'a1b22222222b')) # ['a1b']
# + 匹配前一個(gè)字符1次或多次
print(re.findall('ab+', 'abbaabb')) # ['abb', 'abb']
print(re.findall('ab+', 'abbb')) # ['abbb']
# {n,m} 匹配前一個(gè)字符n到m次
print(re.findall('ab{2}', 'abbb')) # ['abb']
print(re.findall('ab{2,4}', 'abbb')) # ['abb']
print(re.findall('ab{1,}', 'abbb')) # 'ab{1,}' ===> 'ab+'
print(re.findall('ab{0,}', 'abbb')) # 'ab{0,}' ===> 'ab*'
# []
print(re.findall('a[1*-]b', 'a1b a*b a-b')) # []內(nèi)的都為普通字符了帮非,且如果-沒(méi)有被轉(zhuǎn)意的話,應(yīng)該放到[]的開(kāi)頭或結(jié)尾
print(re.findall('a[^1*-]b', 'a1b a*b a-b a=b')) # []內(nèi)的^代表的意思是取反讹蘑,所以結(jié)果為['a=b']
print(re.findall('a[0-9]b', 'a1b a*b a-b a=b')) #['a1b']
print(re.findall('a[a-z]b', 'a1b a*b a-b a=b aeb')) # ['aeb']['a=b']
print(re.findall('a[a-zA-Z]b', 'a1b a*b a-b a=b aeb aEb')) # ['aeb', 'aEb']
# \# print(re.findall('a\\c','a\c')) #對(duì)于正則來(lái)說(shuō)a\\c確實(shí)可以匹配到a\c,但是在python解釋器讀取a\\c時(shí)末盔,會(huì)發(fā)生轉(zhuǎn)義,然后交給re去執(zhí)行座慰,所以拋出異常
print(re.findall(r'a\\c', 'a\c')) # r代表告訴解釋器使用rawstring陨舱,即原生字符串,把我們正則內(nèi)的所有符號(hào)都當(dāng)普通字符處理版仔,不要轉(zhuǎn)義
print(re.findall('a\\\\c', 'a\c')) # 同上面的意思一樣游盲,和上面的結(jié)果一樣都是['a\\c']
# (): 匹配括號(hào)里面的內(nèi)容
print(re.findall('ab+', 'ababab123')) # ['ab', 'ab', 'ab']
print(re.findall('(ab)+123', 'ababab123')) # ['ab'],匹配到末尾的ab123中的ab
print(re.findall('(?:ab)+123', 'ababab123')) # findall的結(jié)果不是匹配的全部?jī)?nèi)容邦尊,而是組內(nèi)的內(nèi)容,?:可以讓結(jié)果為匹配的全部?jī)?nèi)容
# |
print(re.findall('compan(?:y|ies)', 'Too many companies have gone bankrupt, and the next one is my company'))
方法
# ===========================re模塊提供的方法介紹===========================
import re
#1
print(re.findall('e','alex make love') ) #['e', 'e', 'e'],返回所有滿足匹配條件的結(jié)果,放在列表里
#2
print(re.search('e','alex make love').group()) #e,只到找到第一個(gè)匹配然后返回一個(gè)包含匹配信息的對(duì)象,該對(duì)象可以通過(guò)調(diào)用group()方法得到匹配的字符串,如果字符串沒(méi)有匹配背桐,則返回None优烧。
#3
print(re.match('e','alex make love')) #None,同search,不過(guò)在字符串開(kāi)始處進(jìn)行匹配,完全可以用search+^代替match
#4
print(re.split('[ab]','abcd')) #['', '', 'cd']蝉揍,先按'a'分割得到''和'bcd',再對(duì)''和'bcd'分別按'b'分割
#5
print('===>',re.sub('a','A','alex make love')) #===> Alex mAke love,不指定n畦娄,默認(rèn)替換所有
print('===>',re.sub('a','A','alex make love',1)) #===> Alex make love
print('===>',re.sub('a','A','alex make love',2)) #===> Alex mAke love
print('===>',re.sub('^(\w+)(.*?\s)(\w+)(.*?\s)(\w+)(.*?)$',r'\5\2\3\4\1','alex make love')) #===> love make alex
print('===>',re.subn('a','A','alex make love')) #===> ('Alex mAke love', 2),結(jié)果帶有總共替換的個(gè)數(shù)
#6
obj=re.compile('\d{2}')
print(obj.search('abc123eeee').group()) #12
print(obj.findall('abc123eeee')) #['12'],重用了obj