
Python爬蟲正則表達式常用符號和方法
在python語言中,我們經(jīng)常會用到python爬蟲的正則表達式,下面小編通過本篇文章給大家介紹python爬蟲正則表達式常用的符號和方法,以及具體用法,感興趣的童鞋快來看看吧。
正則表達式并不是Python的一部分。正則表達式是用于處理字符串的強大工具,擁有自己獨特的語法以及一個獨立的處理引擎,效率上可能不如str自帶的方法,但功能十分強大。得益于這一點,在提供了正則表達式的語言里,正則表達式的語法都是一樣的,區(qū)別只在于不同的編程語言實現(xiàn)支持的語法數(shù)量不同;但不用擔心,不被支持的語法通常是不常用的部分。
1、常用符號
. :匹配任意字符,換行符 \n 除外
:匹配前一個字符0次或無限次
? :匹配前一個字符0次或1次
.* :貪心算法,盡可能的匹配多的字符
.*? :非貪心算法
() :括號內(nèi)的數(shù)據(jù)作為結(jié)果返回
2、常用方法
findall:匹配所有符合規(guī)律的內(nèi)容,返回包含結(jié)果的列表
Search:匹配并提取第一個符合規(guī)律的內(nèi)容,返回一個正則表達式對象
Sub:替換符合規(guī)律的內(nèi)容,返回替換后的值
3、使用示例
(1). 的使用舉例,匹配任意字符,換行符 \n 除外
import re #導入re庫文件
a = 'xy123'
b = re.findall('x..',a)
print b
打印的結(jié)果為:['xy1'] ,每個 . 表示一個占位符
(2) * 的使用舉例,匹配前一個字符0次或無限次
a = 'xyxy123'
b = re.findall('x*',a)
print b
打印的結(jié)果為:['x', '', 'x', '', '', '', '', '']
(3) ? 的使用舉例,匹配前一個字符0次或1次
a = 'xy123'
b = re.findall('x?',a)
print b
打印的結(jié)果為:['x', '', '', '', '', '']
(4) .* 的使用舉例
secret_code = 'hadkfalifexxIxxfasdjifja134xxlovexx23345sdfxxyouxx8dfse'
b = re.findall('xx.*xx',secret_code)
print b
打印的結(jié)果為:['xxIxxfasdjifja134xxlovexx23345sdfxxyouxx']
(5).*?的使用舉例
secret_code = 'hadkfalifexxIxxfasdjifja134xxlovexx23345sdfxxyouxx8dfse'
c = re.findall('xx.*?xx',secret_code)
print c
打印的結(jié)果為:['xxIxx', 'xxlovexx', 'xxyouxx']
(6) ()的使用舉例
secret_code = 'hadkfalifexxIxxfasdjifja134xxlovexx23345sdfxxyouxx8dfse'
d = re.findall('xx(.*?)xx',secret_code)
print d
打印的結(jié)果為:['I', 'love', 'you'] ,括號內(nèi)的數(shù)據(jù)作為返回的結(jié)果
(7) re.S的使用舉例
s = '''sdfxxhello
xxfsdfxxworldxxasdf'''
d = re.findall('xx(.*?)xx',s,re.S)
print d
打印的結(jié)果為:['hello\n', 'world'] ,re.S的作用是使 . 在匹配時包括 \n
(8) findall的使用舉例
s2 = 'asdfxxIxx123xxlovexxdfd'
f2 = re.findall('xx(. ?)xx123xx(. ?)xx',s2)
print f20
打印的結(jié)果為:love
這時f2為含有一個元組的列表,該元組包含兩個元素,該元組中的兩個元素為兩個()匹配到的內(nèi)容,如果s2包含多個'xx(. ?)xx123xx(. ?)xx'這樣的子串,則f2包含多個元組;
(9) search的使用舉例
s2 = 'asdfxxIxx123xxlovexxdfd'
f = re.search('xx(. ?)xx123xx(. ?)xx',s2).group(2)
print f
打印的結(jié)果為:love
.group(2) 表示返回第二個括號匹配到的內(nèi)容,如果是 .group(1), 則打印的就是:I
(10)sub的使用舉例
s = '123rrrrr123'
output = re.sub('123(.*?)123','123%d123'%789,s)
print output
打印的結(jié)果為:123789123
其中的%d類似于C語言中的%d,如果 output=re.sub('123(.*?)123','123789123',s),輸出結(jié)果也為: 123789123
(11) \d 的使用舉例,用于匹配數(shù)字
a = 'asdfasf1234567fasd555fas'
b = re.findall('(\d+)',a)
print b
打印的結(jié)果為:['1234567', '555'] , \d+ 可以匹配數(shù)字字符串;
以上就是python爬蟲正則表達式的一些常用符號和語法,希望對python初學者學習有所幫助。
數(shù)據(jù)分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
LSTM 模型輸入長度選擇技巧:提升序列建模效能的關(guān)鍵? 在循環(huán)神經(jīng)網(wǎng)絡(RNN)家族中,長短期記憶網(wǎng)絡(LSTM)憑借其解決長序列 ...
2025-07-11CDA 數(shù)據(jù)分析師報考條件詳解與準備指南? ? 在數(shù)據(jù)驅(qū)動決策的時代浪潮下,CDA 數(shù)據(jù)分析師認證愈發(fā)受到矚目,成為眾多有志投身數(shù) ...
2025-07-11數(shù)據(jù)透視表中兩列相乘合計的實用指南? 在數(shù)據(jù)分析的日常工作中,數(shù)據(jù)透視表憑借其強大的數(shù)據(jù)匯總和分析功能,成為了 Excel 用戶 ...
2025-07-11尊敬的考生: 您好! 我們誠摯通知您,CDA Level I和 Level II考試大綱將于 2025年7月25日 實施重大更新。 此次更新旨在確保認 ...
2025-07-10BI 大數(shù)據(jù)分析師:連接數(shù)據(jù)與業(yè)務的價值轉(zhuǎn)化者? ? 在大數(shù)據(jù)與商業(yè)智能(Business Intelligence,簡稱 BI)深度融合的時代,BI ...
2025-07-10SQL 在預測分析中的應用:從數(shù)據(jù)查詢到趨勢預判? ? 在數(shù)據(jù)驅(qū)動決策的時代,預測分析作為挖掘數(shù)據(jù)潛在價值的核心手段,正被廣泛 ...
2025-07-10數(shù)據(jù)查詢結(jié)束后:分析師的收尾工作與價值深化? ? 在數(shù)據(jù)分析的全流程中,“query end”(查詢結(jié)束)并非工作的終點,而是將數(shù) ...
2025-07-10CDA 數(shù)據(jù)分析師考試:從報考到取證的全攻略? 在數(shù)字經(jīng)濟蓬勃發(fā)展的今天,數(shù)據(jù)分析師已成為各行業(yè)爭搶的核心人才,而 CDA(Certi ...
2025-07-09【CDA干貨】單樣本趨勢性檢驗:捕捉數(shù)據(jù)背后的時間軌跡? 在數(shù)據(jù)分析的版圖中,單樣本趨勢性檢驗如同一位耐心的偵探,專注于從單 ...
2025-07-09year_month數(shù)據(jù)類型:時間維度的精準切片? ? 在數(shù)據(jù)的世界里,時間是最不可或缺的維度之一,而year_month數(shù)據(jù)類型就像一把精準 ...
2025-07-09CDA 備考干貨:Python 在數(shù)據(jù)分析中的核心應用與實戰(zhàn)技巧? ? 在 CDA 數(shù)據(jù)分析師認證考試中,Python 作為數(shù)據(jù)處理與分析的核心 ...
2025-07-08SPSS 中的 Mann-Kendall 檢驗:數(shù)據(jù)趨勢與突變分析的有力工具? ? ? 在數(shù)據(jù)分析的廣袤領(lǐng)域中,準確捕捉數(shù)據(jù)的趨勢變化以及識別 ...
2025-07-08備戰(zhàn) CDA 數(shù)據(jù)分析師考試:需要多久?如何規(guī)劃? CDA(Certified Data Analyst)數(shù)據(jù)分析師認證作為國內(nèi)權(quán)威的數(shù)據(jù)分析能力認證 ...
2025-07-08LSTM 輸出不確定的成因、影響與應對策略? 長短期記憶網(wǎng)絡(LSTM)作為循環(huán)神經(jīng)網(wǎng)絡(RNN)的一種變體,憑借獨特的門控機制,在 ...
2025-07-07統(tǒng)計學方法在市場調(diào)研數(shù)據(jù)中的深度應用? 市場調(diào)研是企業(yè)洞察市場動態(tài)、了解消費者需求的重要途徑,而統(tǒng)計學方法則是市場調(diào)研數(shù) ...
2025-07-07CDA數(shù)據(jù)分析師證書考試全攻略? 在數(shù)字化浪潮席卷全球的當下,數(shù)據(jù)已成為企業(yè)決策、行業(yè)發(fā)展的核心驅(qū)動力,數(shù)據(jù)分析師也因此成為 ...
2025-07-07剖析 CDA 數(shù)據(jù)分析師考試題型:解鎖高效備考與答題策略? CDA(Certified Data Analyst)數(shù)據(jù)分析師考試作為衡量數(shù)據(jù)專業(yè)能力的 ...
2025-07-04SQL Server 字符串截取轉(zhuǎn)日期:解鎖數(shù)據(jù)處理的關(guān)鍵技能? 在數(shù)據(jù)處理與分析工作中,數(shù)據(jù)格式的規(guī)范性是保證后續(xù)分析準確性的基礎(chǔ) ...
2025-07-04CDA 數(shù)據(jù)分析師視角:從數(shù)據(jù)迷霧中探尋商業(yè)真相? 在數(shù)字化浪潮席卷全球的今天,數(shù)據(jù)已成為企業(yè)決策的核心驅(qū)動力,CDA(Certifie ...
2025-07-04CDA 數(shù)據(jù)分析師:開啟數(shù)據(jù)職業(yè)發(fā)展新征程? ? 在數(shù)據(jù)成為核心生產(chǎn)要素的今天,數(shù)據(jù)分析師的職業(yè)價值愈發(fā)凸顯。CDA(Certified D ...
2025-07-03