python如何通過(guò)正則匹配指定字符開頭與結(jié)束提取中間內(nèi)容
一、提取包含始末字符
1、起始字符串固定
a = re.findall('起始字符串.*結(jié)束字符串',str)2、起始字符串不固定(即從首字符串提取到固定的字符串結(jié)束),用^指定從首字符串開始
a = re.findall('^.*結(jié)束字符串',str)二、不包含始末字符串
#方法1
a = re.findall('(?<=始字符串).*?(?=末字符串)',str)
#方法2
a = re.findall('始字符串(.*?)末字符串',str)在 re.findall()的方法中 '始字符串.末字符串’ 可以匹配到相同的值直到最后一個(gè)值;如果參數(shù)為 '始字符串.?末字符串’則只匹配到第一個(gè)值。其實(shí)使用.*和.+都能提取特定始末字符串中間的內(nèi)容,下面順便說(shuō)下兩者的區(qū)別。
三、.*和.+正則提取的區(qū)別
.:匹配任意字符
*:匹配0個(gè)或多個(gè)字符
?:非貪婪模式,在符合的條件下,盡可能少的匹配(盡可能短的匹配)
str2 = "aabab"
a = re.findall('a.*?b',str2) #結(jié)果:['aab', 'ab']
b = re.findall('a.+?b',str2) #結(jié)果:['aab'].?:匹配aab和ab ,因?yàn)榭梢云ヅ?個(gè)字符,所以可以匹配得到ab
.+?:匹配aab,因?yàn)?必須a和b中間至少有一個(gè)字符,所以排除了ab
四、起始有無(wú)^的區(qū)別
str2 = "aabab"
c = re.findall('.*',str2) #結(jié)果:['aabab', '']
d = re.findall('^.*',str2) #結(jié)果:['aabab']五、pandas對(duì)具體列的內(nèi)容通過(guò)正則表達(dá)式進(jìn)行數(shù)據(jù)提取
1.使用前要確保該列的類型統(tǒng)一,str或者float格式,最好事先通過(guò)astype強(qiáng)制轉(zhuǎn)換一下
2.df[‘新列名’]=df[‘提取的列名’].str.extract(‘正則表達(dá)式’, expand = True)
六、遇到的報(bào)錯(cuò)
報(bào)錯(cuò):pattern contains no capture groups
(翻譯:模式不包含捕獲組)
解決:根據(jù)docs ,您需要為 str.extract 指定一個(gè)捕獲組(即括號(hào))好,提取。
參考文章:
https://www.cnblogs.com/ZhangHT97/p/13427325.html
https://www.cnblogs.com/YouJeffrey/p/15209895.html
https://blog.csdn.net/dudu3332/article/details/111555572
到此這篇關(guān)于python通過(guò)正則匹配指定字符開頭與結(jié)束提取中間內(nèi)容的文章就介紹到這了,更多相關(guān)python正則匹配提取中間內(nèi)容內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何解決requests,已經(jīng)安裝卻無(wú)法import問(wèn)題
這篇文章主要介紹了如何解決requests,已經(jīng)安裝卻無(wú)法import問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06
python實(shí)現(xiàn)微信接口(itchat)詳細(xì)介紹
這篇文章主要介紹了python實(shí)現(xiàn)微信接口(itchat)詳細(xì)介紹,小編覺得挺不錯(cuò)的,這里分享給大家,供需要的朋友參考。2017-10-10
Python利用內(nèi)置庫(kù)實(shí)現(xiàn)數(shù)據(jù)的加密與校驗(yàn)
python使用自定義user-agent抓取網(wǎng)頁(yè)的方法
python實(shí)現(xiàn)年會(huì)抽獎(jiǎng)程序

