欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python正則表達(dá)re模塊之findall()函數(shù)詳解

 更新時(shí)間:2022年07月07日 09:38:19   作者:向陽(yáng)樹(shù)  
在python中,通過(guò)內(nèi)嵌集成re模塊可以直接調(diào)用來(lái)實(shí)現(xiàn)正則匹配,其中re.findall()函數(shù)可以遍歷匹配,可以獲取字符串中所有匹配的字符串,返回一個(gè)列表,這篇文章主要給大家介紹了關(guān)于Python正則表達(dá)re模塊之findall()函數(shù)的相關(guān)資料,需要的朋友可以參考下

一、re.findall函數(shù)介紹

它在re.py中有定義:

def findall(pattern, string, flags=0):
    """Return a list of all non-overlapping matches in the string.

    If one or more capturing groups are present in the pattern, return
    a list of groups; this will be a list of tuples if the pattern
    has more than one group.

    Empty matches are included in the result."""

    return _compile(pattern, flags).findall(string)

返回string中所有與pattern匹配的全部字符串,返回形式為數(shù)組。

findall()函數(shù)的兩種表示形式

import re
kk = re.compile(r'\d+')
kk.findall('one1two2three3four4')
#[1,2,3,4]
 
#注意此處findall()的用法,可傳兩個(gè)參數(shù);
kk = re.compile(r'\d+')
re.findall(kk,"one123")
#[1,2,3]

二、實(shí)例代碼

后面會(huì)講解代碼里的各個(gè)部分,先列出來(lái)~

import re
 
str = 'aabbabaabbaa'

# 一個(gè)"."就是匹配除 \n (換行符)以外的任意一個(gè)字符
print(re.findall(r'a.b',str))#['aab', 'aab']

# *前面的字符出現(xiàn)0次或以上
print(re.findall(r'a*b',str))#['aab', 'b', 'ab', 'aab', 'b']

# 貪婪,匹配從.*前面為開(kāi)始到后面為結(jié)束的所有內(nèi)容
print(re.findall(r'a.*b',str))#['aabbabaabb']

# 非貪婪,遇到開(kāi)始和結(jié)束就進(jìn)行截取,因此截取多次符合的結(jié)果,中間沒(méi)有字符也會(huì)被截取
print(re.findall(r'a.*?b',str))#['aab', 'ab', 'aab']

# 非貪婪,與上面一樣,只是與上面的相比多了一個(gè)括號(hào),只保留括號(hào)的內(nèi)容
print(re.findall(r'a(.*?)b',str))#['a', '', 'a']
 
str = '''aabbab
         aabbaa
         bb'''     #后面多加了2個(gè)b

# 沒(méi)有把最后一個(gè)換行的aab算進(jìn)來(lái)
print(re.findall(r'a.*?b',str))#['aab', 'ab', 'aab']

# re.S不會(huì)對(duì)\n進(jìn)行中斷
print(re.findall(r'a.*?b',str,re.S))#['aab', 'ab', 'aab', 'aa\n         b']

三、re.findall中正則表達(dá)式(.*?)

字符串是

str = 'aabbabaabbaa'

1. 符號(hào) . 就 是匹配除 \n (換行符)以外的任意一個(gè)字符

print(re.findall(r'a.b',str))
#['aab', 'aab']

2.符號(hào) * 前面的字符出現(xiàn)0次或以上

print(re.findall(r'a*b',str))
#['aab', 'b', 'ab', 'aab', 'b']

3.符號(hào).* 貪婪,匹配從.*前面為開(kāi)始到后面為結(jié)束的所有內(nèi)容

print(re.findall(r'a.*b',str))
#['aabbabaabb']

4.符號(hào).*? 非貪婪,遇到開(kāi)始和結(jié)束就進(jìn)行截取,因此截取多次符合的結(jié)果,中間沒(méi)有字符也會(huì)被截取

print(re.findall(r'a.*?b',str))
#['aab', 'ab', 'aab']

5.符號(hào)(.*?) 非貪婪,與上面一樣,只是與上面的相比多了一個(gè)括號(hào),只保留括號(hào)的內(nèi)容

print(re.findall(r'a(.*?)b',str))
#['a', '', 'a']

關(guān)于帶括號(hào)與不帶括號(hào)的區(qū)別

import re

string="abcdefg  acbdgef  abcdgfe  cadbgfe"

#不帶括號(hào)
regex=re.compile("((\w+)\s+\w+)")
print(regex.findall(string))
#輸出:[('abcdefg  acbdgef', 'abcdefg'), ('abcdgfe  cadbgfe', 'abcdgfe')]

regex1=re.compile("(\w+)\s+\w+")
print(regex1.findall(string))
#輸出:['abcdefg', 'abcdgfe']

regex2=re.compile("\w+\s+\w+")
print(regex2.findall(string))
#輸出:['abcdefg  acbdgef', 'abcdgfe  cadbgfe']
  • 第一個(gè) regex 中帶有2個(gè)括號(hào),其輸出list 中包含2個(gè) tuple
  • 第二個(gè) regex 中帶有1個(gè)括號(hào),其輸出內(nèi)容是括號(hào)匹配到的內(nèi)容,而不是整個(gè)表達(dá)式所匹配到的結(jié)果。
  • 第三個(gè) regex 中不帶括號(hào),其輸出的內(nèi)容就是整個(gè)表達(dá)式所匹配到的內(nèi)容。

實(shí)際上這并不是python特有的,這是正則所特有的 , 任何一門(mén)高級(jí)語(yǔ)言使用正則都滿(mǎn)足這個(gè)特點(diǎn):有括號(hào)時(shí)只能匹配到括號(hào)中的內(nèi)容,沒(méi)有括號(hào)【相當(dāng)于在最外層增加了一個(gè)括號(hào)】。在正則里面 "()" 代表的是分組的意思,一個(gè)括號(hào)代表一個(gè)分組,你只能匹配到 "()" 中的內(nèi)容。

四、re.findall中參數(shù)re.S的意義

1.字符串變?yōu)椋ê竺娑嗉恿?個(gè)b)

str = '''aabbab
         aabbaa
         bb'''

2.參數(shù)無(wú)re.S,沒(méi)有把最后一個(gè)換行的aab算進(jìn)來(lái)

print(re.findall(r'a.*?b',str))
#['aab', 'ab', 'aab']

3.參數(shù)有re.S,不會(huì)對(duì)\n進(jìn)行中斷

print(re.findall(r'a.*?b',str,re.S))
#['aab', 'ab', 'aab', 'aa\n         b']

參考

2. python re模塊findall()詳解

3. Python 正則re模塊之findall()詳解

總結(jié)

到此這篇關(guān)于Python正則表達(dá)re模塊之findall()函數(shù)詳解的文章就介紹到這了,更多相關(guān)Python正則表達(dá)re模塊findall()內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python按比例隨機(jī)切分?jǐn)?shù)據(jù)的實(shí)現(xiàn)

    python按比例隨機(jī)切分?jǐn)?shù)據(jù)的實(shí)現(xiàn)

    這篇文章主要介紹了python按比例隨機(jī)切分?jǐn)?shù)據(jù)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • python實(shí)現(xiàn)八大排序算法(1)

    python實(shí)現(xiàn)八大排序算法(1)

    這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)八大排序算法的第一篇,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-09-09
  • python中列表和元組的區(qū)別

    python中列表和元組的區(qū)別

    給大家詳細(xì)講解了python中列表和元組的區(qū)別,需要的朋友參考一下。
    2017-12-12
  • Python自定義裝飾器原理與用法實(shí)例分析

    Python自定義裝飾器原理與用法實(shí)例分析

    這篇文章主要介紹了Python自定義裝飾器原理與用法,結(jié)合實(shí)例形式較為詳細(xì)的分析了Python自定義裝飾器,帶參數(shù)的裝飾器等概念、原理、實(shí)現(xiàn)方法及相關(guān)使用技巧,需要的朋友可以參考下
    2018-07-07
  • 使用Django的模版來(lái)配合字符串翻譯工作

    使用Django的模版來(lái)配合字符串翻譯工作

    這篇文章主要介紹了使用Django的模版來(lái)配合字符串翻譯工作,Django是最具人氣的Python開(kāi)發(fā)框架,需要的朋友可以參考下
    2015-07-07
  • 基于python cut和qcut的用法及區(qū)別詳解

    基于python cut和qcut的用法及區(qū)別詳解

    今天小編就為大家分享一篇基于python cut和qcut的用法及區(qū)別詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-11-11
  • Python操作word文檔插入圖片和表格的實(shí)例演示

    Python操作word文檔插入圖片和表格的實(shí)例演示

    這篇文章主要給大家介紹了關(guān)于Python操作word文檔插入圖片和表格的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • Python多線程:主線程等待所有子線程結(jié)束代碼

    Python多線程:主線程等待所有子線程結(jié)束代碼

    這篇文章主要介紹了Python多線程:主線程等待所有子線程結(jié)束代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-04-04
  • python執(zhí)行等待程序直到第二天零點(diǎn)的方法

    python執(zhí)行等待程序直到第二天零點(diǎn)的方法

    這篇文章主要介紹了python執(zhí)行等待程序直到第二天零點(diǎn)的方法,涉及Python等待程序的實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2015-04-04
  • Django choices下拉列表綁定實(shí)例

    Django choices下拉列表綁定實(shí)例

    這篇文章主要介紹了Django choices下拉列表綁定實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-03-03

最新評(píng)論