正則离咐、xpath谱俭、bs4的使用方法

正則表達式

  • 正則表達式是一個特殊的字符序列,它能幫助你方便的檢查一個字符串是否與某種模式匹配宵蛀。
  • re 模塊使 Python 語言擁有全部的正則表達式功能昆著。
import re 
pattern = re.compile(r'\d+')   # 查找數字
result1 = pattern.findall('runoob 123')

##結果為123,類型為list
  • 或者
import re 
result1=re.findall(r'\d+','runoob 123')

具體怎么寫正則表達式就不多說了术陶,網上教程很多凑懂,多寫多練才能更好掌握。

bs4

  • 之前介紹了用bs4來解析 html 標簽梧宫,完成之后就可以調用bs4的各種方法來提取數據接谨。

  • 基本用法

from bs4 import BeautifulSoup

soup = BeautifulSoup(html,'lxml')
soup.prettify() #格式化網頁代碼,缺少的補齊等等
soup.title #獲取<title>標簽
soup.title.string #獲取title的文本內容
soup.p #獲取p標簽
soup.p["class"] #獲取p標簽的class屬性
soup.find_all('a') #返回所有的a標簽塘匣,返回列表

更多詳細看官方文檔:https://www.crummy.com/software/BeautifulSoup/bs4/doc.zh/

xpath

  • 簡單來說脓豪,xpath 就是一種在 XML 文檔中查找信息的語言。

  • 基本用法

test = html.xpath('/html/head/title') #表示匹配根節(jié)點下的head節(jié)點下的title元素節(jié)點

test = html.xpath('/html/head/title/text()')#表示匹配根節(jié)點下的head節(jié)點下的title元素節(jié)點中的文本節(jié)點
test = html.xpath('/a/@href') #表示匹配a元素節(jié)點下的子節(jié)點中的 href 屬性節(jié)點

test = html.xpath('//a[@href]') #匹配帶有 href 屬性的 <a> 標簽

test = html.xpath('//a[@href="image1.html"]') #指定帶有 href 屬性且值為 image1.html 的 <a> 標簽

xpath 方法返回字符串或者匹配列表忌卤,匹配列表中的每一項都是 lxml.etree._Element 對象扫夜。

如上面的 test 作為測試樣例,test 中的每一項都是一個 _Element 對象埠巨。我們寫爬蟲最終獲取的數據信息历谍,就是通過_Element 對象的方法來獲取的。

test = html.xpath('//a[@href="image1.html"]')
obj = test[0]
obj.tag #返回標簽名'a'
obj.attrib #返回屬性與值組成的字典{'href': 'image1.html'}
obj.get('href') #返回指定屬性的值
obj.text #返回文本值

使用XPath有一個方便的地方在于辣垒,可以直接使用Chrome瀏覽器來獲取XPath路徑望侈,方法是:在網頁中右擊->選擇審查元素(或者使用F12打開) 就可以在elements中查看網頁的html標簽了,找到你想要獲取XPath的標簽勋桶,右擊->Copy XPath 就已經將XPath路徑復制到了剪切板脱衙。

常用的樣板

正則

import requests
import re#導入相關的庫
url="https://www.ftms.com.cn/footernav/tendernotice"
data = requests.get(url)
pattern = re.compile(r'<title>(.*?)</title>')   # 查找數字
title = pattern.findall(data.content)
print(title)

bs4

from bs4 import BeautifulSoup
import lxml
import requests

url='https://www.ftms.com.cn/footernav/tendernotice'
data = requests.get(url)
soup = BeautifulSoup(data.content, 'lxml')
title = soup.find_all('title')[0].string

print(title)

xpath

import requests
from lxml import etree

url = 'https://www.ftms.com.cn/footernav/tendernotice'
data = requests.get(url) 
html = etree.HTML(data.content)
title = html.xpath('/html/head/title/text()') 

print(title)
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末侥猬,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子捐韩,更是在濱河造成了極大的恐慌退唠,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件荤胁,死亡現(xiàn)場離奇詭異瞧预,居然都是意外死亡,警方通過查閱死者的電腦和手機仅政,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進店門垢油,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人圆丹,你說我怎么就攤上這事滩愁。” “怎么了辫封?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵硝枉,是天一觀的道長。 經常有香客問我倦微,道長妻味,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任欣福,我火速辦了婚禮弧可,結果婚禮上,老公的妹妹穿的比我還像新娘劣欢。我一直安慰自己,他們只是感情好裁良,可當我...
    茶點故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布凿将。 她就那樣靜靜地躺著,像睡著了一般价脾。 火紅的嫁衣襯著肌膚如雪牧抵。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天侨把,我揣著相機與錄音犀变,去河邊找鬼。 笑死秋柄,一個胖子當著我的面吹牛获枝,可吹牛的內容都是我干的。 我是一名探鬼主播骇笔,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼省店,長吁一口氣:“原來是場噩夢啊……” “哼嚣崭!你這毒婦竟也來了?” 一聲冷哼從身側響起懦傍,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤雹舀,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后粗俱,有當地人在樹林里發(fā)現(xiàn)了一具尸體说榆,經...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年寸认,在試婚紗的時候發(fā)現(xiàn)自己被綠了签财。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,785評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡废麻,死狀恐怖荠卷,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情烛愧,我是刑警寧澤油宜,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站怜姿,受9級特大地震影響慎冤,放射性物質發(fā)生泄漏。R本人自食惡果不足惜沧卢,卻給世界環(huán)境...
    茶點故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一蚁堤、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧但狭,春花似錦披诗、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至唱歧,卻和暖如春宪摧,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背颅崩。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工几于, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人沿后。 一個月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓沿彭,卻偏偏與公主長得像,于是被迫代替她去往敵國和親尖滚。 傳聞我的和親對象是個殘疾皇子膝蜈,可洞房花燭夜當晚...
    茶點故事閱讀 44,713評論 2 354

推薦閱讀更多精彩內容