日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

re.findall为什么返回的元素会是个元素为元组的列表类型呢

發布時間:2025/3/19 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 re.findall为什么返回的元素会是个元素为元组的列表类型呢 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

問題起源:

如下案例:

s1 = "(\d)([a-zA-Z])" s2 = "ddd.111kkkk6666lll" import re re.findall(s1,s2)輸出結果: [('1', 'k'), ('6', 'l')] 這里就很奇怪,為什么會有這樣的結果呢? 我所預期的是:["1k","6l"]

通過搜索強調findall的特性如下:

findall()返回的是括號所匹配到的結果,多個括號就會返回多個括號分別匹配到的結果, 如果沒有括號就返回就返回整條語句所匹配到的結果;findall本質上是返回多個匹配到的結果,其返回結果為列表類型,無論匹配到多少個;其列表中的每個元素表現形式是由正則表達式中的括號數量所決定的,如果沒有括號即等價于一個括號,那么就是一個字符串,如果存在兩個兩個或兩個以上就會用元組數據類型儲存多個括號內的結果。

所以設計三個實驗來證明:

實驗一:

s1 = "\d[a-zA-Z]" s2 = "ddd.111kkkk6666lll" import re re.findall(s1,s2) 輸出結果: ['1k', '6l']

實驗二:

s1 = "(\d[a-zA-Z])" s2 = "ddd.111kkkk6666lll" import re re.findall(s1,s2) 輸出結果: ['1k', '6l']

實驗三:

s1 = "((\d)([a-zA-Z]))" s2 = "ddd.111kkkk6666lll" import re re.findall(s1,s2) 輸出結果: [('1k', '1', 'k'), ('6l', '6', 'l')]

實驗已經證明,返回括號內的匹配結果,如果有多個括號就會用元組類型存儲匹配多個匹配結果。如果沒有括號等同于最外面加了個括號。

它和re.search有什么區別呢?

re.search僅返回匹配的第一個結果,而匹配回來的結果也可以用group的方法取括號中正則表達部分。主要的區別就是它只返回第一次匹配到的結果;

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))預期結果: 1kkkk 1 kkkk [('1', 'kkkk'), ('6', 'lll')]

?

總結

以上是生活随笔為你收集整理的re.findall为什么返回的元素会是个元素为元组的列表类型呢的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。