re.findall为什么返回的元素会是个元素为元组的列表类型呢
生活随笔
收集整理的這篇文章主要介紹了
re.findall为什么返回的元素会是个元素为元组的列表类型呢
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
問(wèn)題起源:
如下案例:
s1 = "(\d)([a-zA-Z])" s2 = "ddd.111kkkk6666lll" import re re.findall(s1,s2)輸出結(jié)果: [('1', 'k'), ('6', 'l')] 這里就很奇怪,為什么會(huì)有這樣的結(jié)果呢? 我所預(yù)期的是:["1k","6l"]通過(guò)搜索強(qiáng)調(diào)findall的特性如下:
findall()返回的是括號(hào)所匹配到的結(jié)果,多個(gè)括號(hào)就會(huì)返回多個(gè)括號(hào)分別匹配到的結(jié)果, 如果沒(méi)有括號(hào)就返回就返回整條語(yǔ)句所匹配到的結(jié)果;findall本質(zhì)上是返回多個(gè)匹配到的結(jié)果,其返回結(jié)果為列表類(lèi)型,無(wú)論匹配到多少個(gè);其列表中的每個(gè)元素表現(xiàn)形式是由正則表達(dá)式中的括號(hào)數(shù)量所決定的,如果沒(méi)有括號(hào)即等價(jià)于一個(gè)括號(hào),那么就是一個(gè)字符串,如果存在兩個(gè)兩個(gè)或兩個(gè)以上就會(huì)用元組數(shù)據(jù)類(lèi)型儲(chǔ)存多個(gè)括號(hào)內(nèi)的結(jié)果。所以設(shè)計(jì)三個(gè)實(shí)驗(yàn)來(lái)證明:
實(shí)驗(yàn)一:
s1 = "\d[a-zA-Z]" s2 = "ddd.111kkkk6666lll" import re re.findall(s1,s2) 輸出結(jié)果: ['1k', '6l']實(shí)驗(yàn)二:
s1 = "(\d[a-zA-Z])" s2 = "ddd.111kkkk6666lll" import re re.findall(s1,s2) 輸出結(jié)果: ['1k', '6l']實(shí)驗(yàn)三:
s1 = "((\d)([a-zA-Z]))" s2 = "ddd.111kkkk6666lll" import re re.findall(s1,s2) 輸出結(jié)果: [('1k', '1', 'k'), ('6l', '6', 'l')]實(shí)驗(yàn)已經(jīng)證明,返回括號(hào)內(nèi)的匹配結(jié)果,如果有多個(gè)括號(hào)就會(huì)用元組類(lèi)型存儲(chǔ)匹配多個(gè)匹配結(jié)果。如果沒(méi)有括號(hào)等同于最外面加了個(gè)括號(hào)。
它和re.search有什么區(qū)別呢?
re.search僅返回匹配的第一個(gè)結(jié)果,而匹配回來(lái)的結(jié)果也可以用group的方法取括號(hào)中正則表達(dá)部分。主要的區(qū)別就是它只返回第一次匹配到的結(jié)果;
s1 = "(\d)([a-zA-Z]+)" s2 = "ddd.111kkkk6666lll" import re ss = re.search(s1,s2) print(ss.group(0)) print(ss.group(1)) print(ss.group(2)) print(re.findall(s1,s2))預(yù)期結(jié)果: 1kkkk 1 kkkk [('1', 'kkkk'), ('6', 'lll')]?
總結(jié)
以上是生活随笔為你收集整理的re.findall为什么返回的元素会是个元素为元组的列表类型呢的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: linux下直接使用base64就可转换
- 下一篇: 空列表不等同于None