日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線(xiàn)課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Python爬蟲(chóng)之Beautiful Soup模塊

電子設(shè)計(jì) ? 來(lái)源:電子設(shè)計(jì) ? 作者:電子設(shè)計(jì) ? 2020-12-10 21:56 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

模塊安裝

pip3 install beautifulsoup4

模塊導(dǎo)入

from bs4 import BeautifulSoup

示例html內(nèi)容

獲取html內(nèi)容代碼

import requests

headers = {
    "User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/62.0.3202.94 Safari/537.36 115Browser/9.0.0"
}
response = requests.get("https://www.xbiquge6.com/xbqgph.html",headers=headers)
response.encoding = "utf-8"
html = response.text
print(html)

獲取的html內(nèi)容


小說(shuō)排行榜列表

構(gòu)建BeautifulSoup對(duì)象

常用四種解釋器

解釋器 標(biāo)識(shí) 特點(diǎn)
Python標(biāo)準(zhǔn)庫(kù) html.parser Python內(nèi)置,執(zhí)行速度中
lxml的HTML解釋器 lxml 速度快
lxml的XML解釋器 xml 唯一支持XML解析
html5lib html5lib 容錯(cuò)性最好,以瀏覽器方式解析
soup = BeautifulSoup(html, 'html.parser')

還可以解析本地html文件

soup1 = BeautifulSoup(open('index.html'))

.prettify()格式化輸出節(jié)點(diǎn)

通過(guò) . 獲取節(jié)點(diǎn)

title = soup.head.title
print(type(title))
print(title)

結(jié)果是

對(duì)于名稱(chēng)唯一的節(jié)點(diǎn),可以省略層級(jí)

title = soup.title
print(type(title))
print(title)

結(jié)果同樣是

名稱(chēng)不唯一的節(jié)點(diǎn),直接獲取只會(huì)獲取第一個(gè)匹配的節(jié)點(diǎn)

li = soup.li
print(li)

結(jié)果是

find_all根據(jù)條件獲取節(jié)點(diǎn)

find_all( name , attrs , recursive , text , **kwargs )
name :查找所有名字為 name 的tag,字符串對(duì)象會(huì)被自動(dòng)忽略掉;
attrs:根據(jù)屬性查詢(xún),使用字典類(lèi)型;
text :可以搜搜文檔中的字符串內(nèi)容.與 name 參數(shù)的可選值一樣, text 參數(shù)接受 字符串 , 正則表達(dá)式 , 列表, True ;
recursive:調(diào)用tag的 find_all() 方法時(shí),Beautiful Soup會(huì)檢索當(dāng)前tag的所有子孫節(jié)點(diǎn),如果只想搜索tag的直接子節(jié)點(diǎn),可以使用參數(shù) recursive=False ;
limit:find_all() 方法返回全部的搜索結(jié)構(gòu),如果文檔樹(shù)很大那么搜索會(huì)很慢.如果我們不需要全部結(jié)果,可以使用 limit 參數(shù)限制返回結(jié)果的數(shù)量.效果與SQL中的limit關(guān)鍵字類(lèi)似,當(dāng)搜索到的結(jié)果數(shù)量達(dá)到 limit 的限制時(shí),就停止搜索返回結(jié)果;
class_ :通過(guò) class_ 參數(shù)搜索有指定CSS類(lèi)名的tag,class_ 參數(shù)同樣接受不同類(lèi)型的 過(guò)濾器 ,字符串,正則表達(dá)式,方法或 True。

根據(jù)標(biāo)簽名字

lis = soup.find_all(nam)
for item in lis:
    print(item)

結(jié)果是

根據(jù)標(biāo)簽屬性

屬性和值以字典形式傳入

lis = soup.find_all(attrs={"class":"s2"})
for item in lis:
    print(item)

結(jié)果是
作品名稱(chēng)
我能舉報(bào)萬(wàn)物
女戰(zhàn)神的黑包群
花崗巖之怒
超神機(jī)械師
無(wú)量真途
我的細(xì)胞監(jiān)獄
前任無(wú)雙
元陽(yáng)道君
逆成長(zhǎng)巨星
承包大明

限制搜索范圍

find_all 方法會(huì)搜索當(dāng)前標(biāo)簽的所有子孫節(jié)點(diǎn),如果只想搜索直接子節(jié)點(diǎn),可以使用參數(shù) recursive=False

遍歷獲取子節(jié)點(diǎn)

.contents獲取所有子節(jié)點(diǎn)

以列表形式返回所有子節(jié)點(diǎn),要注意,列表里面還會(huì)摻雜 '/n'

ul = soup.ul
print(ul)
print(ul.contents)

結(jié)果是
['/n',

.children獲取所有子節(jié)點(diǎn)

返回一個(gè)list生成器對(duì)象

ul = soup.ul
print(ul.children)
print(list(ul.children))

結(jié)果是
['/n', 

.descendants遍歷所有子孫節(jié)點(diǎn)

ul = soup.ul
for item in ul.descendants:
    print(item)

結(jié)果是(中間很多'/n'空行我刪掉了)
首頁(yè) 首頁(yè) 永久書(shū)架 永久書(shū)架 玄幻奇幻 玄幻奇幻 武俠仙俠 武俠仙俠 都市言情 都市言情 歷史軍事 歷史軍事 科幻靈異 科幻靈異 網(wǎng)游競(jìng)技 網(wǎng)游競(jìng)技 女頻頻道 女頻頻道 完本小說(shuō) 完本小說(shuō) 排行榜單 排行榜單 臨時(shí)書(shū)架 臨時(shí)書(shū)架

獲取其父節(jié)點(diǎn)

a = soup.li.a
print(a)
p = a.parent
print(p)

結(jié)果是
首頁(yè)

提取節(jié)點(diǎn)信息

節(jié)點(diǎn)名稱(chēng)

感覺(jué)沒(méi)什么用

title = soup.title
print(title.name)

結(jié)果是
title

節(jié)點(diǎn)屬性

a = soup.li.a
print(a)
print(a.attrs)    # 獲取所有屬性,返回字典形式
print(a['href'])# 獲取a節(jié)點(diǎn)的href屬性值

結(jié)果是
首頁(yè)
{'href': '/'}
/

節(jié)點(diǎn)文本

a = soup.li.a
print(type(a.string)) # 節(jié)點(diǎn)內(nèi)文本的類(lèi)型
print(a.string) # 獲取節(jié)點(diǎn)內(nèi)的文本內(nèi)容
print(a.get_text())    # 也是獲取節(jié)點(diǎn)內(nèi)的文本內(nèi)容
結(jié)果是

首頁(yè)

注意?。?!如果節(jié)點(diǎn)內(nèi)文本是注釋?zhuān)瑒t用string取出文本時(shí)會(huì)自動(dòng)去除注釋標(biāo)記
注釋的類(lèi)型:,可以通過(guò)類(lèi)型判斷

遍歷獲取所有子孫節(jié)點(diǎn)中的文本

for string in soup.stripped_strings:  # 去除多余空白內(nèi)容
    print(repr(string))
想進(jìn)一步了解編程開(kāi)發(fā)相關(guān)知識(shí),與我一同成長(zhǎng)進(jìn)步,請(qǐng)關(guān)注我的公眾號(hào)“松果倉(cāng)庫(kù)”,共同分享宅&程序員的各類(lèi)資源,謝謝?。。?br />
審核編輯 黃昊宇
聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • JAVA
    +關(guān)注

    關(guān)注

    20

    文章

    3012

    瀏覽量

    116877
  • 人工智能
    +關(guān)注

    關(guān)注

    1821

    文章

    50366

    瀏覽量

    267060
  • python
    +關(guān)注

    關(guān)注

    58

    文章

    4889

    瀏覽量

    90330
  • 爬蟲(chóng)
    +關(guān)注

    關(guān)注

    0

    文章

    87

    瀏覽量

    8183
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    Python全棧一課通(470集)(12.96 GB)-網(wǎng)盤(pán)資源下載

    只懂單一節(jié)點(diǎn)的“螺絲釘”,往往是最先被優(yōu)化、被降薪的群體。(看讠果aixuetang。xyz) 如果將《470集吃透 Python 全棧:Web 開(kāi)發(fā)、接口、爬蟲(chóng)、自動(dòng)化全包含》置于經(jīng)濟(jì)學(xué)的顯微鏡下,它
    發(fā)表于 04-19 16:30

    使用PYTHON進(jìn)行的跨平臺(tái)仿真

    如何使用編程語(yǔ)言Python來(lái)調(diào)用和控制VirtualLab Fusion中的模擬。請(qǐng)查看下面鏈接的文檔,以找到關(guān)于如何設(shè)置和使用Python和VirtualLab Fusion之間的接口的詳細(xì)指南,以及一個(gè)
    發(fā)表于 04-02 08:21

    [VirtualLab] 使用Python運(yùn)行VirtualLab Fusion光學(xué)仿真

    摘要 VirtualLab Fusion允許Python外部訪(fǎng)問(wèn)其建模技術(shù)、求解器和結(jié)果。這個(gè)用例介紹了一種使用路徑變量和Visual Studio代碼將Python連接到VirtualLab
    發(fā)表于 03-31 09:39

    MAXM17516:高效電源模塊的卓越

    MAXM17516:高效電源模塊的卓越選 在電子設(shè)計(jì)領(lǐng)域,電源模塊的性能直接影響著整個(gè)系統(tǒng)的穩(wěn)定性和效率。今天,我們就來(lái)深入探討一款備受關(guān)注的電源模塊——MAXM17516。 文件下
    的頭像 發(fā)表于 03-12 16:45 ?187次閱讀

    京東關(guān)鍵詞搜索商品列表的Python實(shí)戰(zhàn)

    " return url def _parse_page(self, html): """解析頁(yè)面,提取商品信息""" soup = BeautifulSoup(html, "html.parser
    的頭像 發(fā)表于 01-09 10:34 ?1185次閱讀

    京東關(guān)鍵詞搜索商品列表的Python爬蟲(chóng)實(shí)戰(zhàn)

    京東關(guān)鍵詞搜索商品列表 Python 爬蟲(chóng)實(shí)戰(zhàn) 你想要實(shí)現(xiàn)京東關(guān)鍵詞搜索商品的爬蟲(chóng),我會(huì)從 合規(guī)聲明、環(huán)境準(zhǔn)備、頁(yè)面分析、代碼實(shí)現(xiàn)、反爬優(yōu)化 五個(gè)方面展開(kāi),幫助你完成實(shí)戰(zhàn)項(xiàng)目。 一、前置聲明(重要
    的頭像 發(fā)表于 01-04 10:16 ?1358次閱讀

    【睿擎派】EtherCAT總線(xiàn)IO模塊讀寫(xiě)

    在上一篇文章《【睿擎派】CANOpen總線(xiàn)IO模塊讀寫(xiě)(DS401協(xié)議)》我寫(xiě)了關(guān)于睿擎派上CANOpen的IO模塊通信,為什么先寫(xiě)CANOpen?說(shuō)來(lái)也有挺意思,是因?yàn)樵陬G媾缮蠈?duì)接
    的頭像 發(fā)表于 12-31 19:07 ?5981次閱讀
    【睿擎派】EtherCAT總線(xiàn)<b class='flag-5'>之</b>IO<b class='flag-5'>模塊</b>讀寫(xiě)

    沒(méi)有專(zhuān)利的opencv-python 版本

    所有 官方發(fā)布的 opencv-python 核心版本(無(wú) contrib 擴(kuò)展)都無(wú)專(zhuān)利風(fēng)險(xiǎn)——專(zhuān)利問(wèn)題僅存在于 opencv-contrib-python 擴(kuò)展模塊中的少數(shù)算法(如早期 SIFT
    發(fā)表于 12-13 12:37

    # 深度解析:爬蟲(chóng)技術(shù)獲取淘寶商品詳情并封裝為API的全流程應(yīng)用

    需求。本文將深入探討如何借助爬蟲(chóng)技術(shù)實(shí)現(xiàn)淘寶商品詳情的獲取,并將其高效封裝為API。 一、爬蟲(chóng)技術(shù)核心原理與工具 1.1 爬蟲(chóng)運(yùn)行機(jī)制 網(wǎng)絡(luò)爬蟲(chóng)本質(zhì)上是一種遵循特定規(guī)則,自動(dòng)抓取網(wǎng)頁(yè)信
    的頭像 發(fā)表于 11-17 09:29 ?508次閱讀

    Python 給 Amazon 做“全身 CT”——可量產(chǎn)、可擴(kuò)展的商品詳情爬蟲(chóng)實(shí)戰(zhàn)

    一、技術(shù)選型:為什么選 Python 而不是 Java? 結(jié)論: “調(diào)研階段用 Python,上線(xiàn)后如果 QPS 爆表再考慮 Java 重構(gòu)?!?二、整體架構(gòu)速覽(3 分鐘看懂) 三、開(kāi)發(fā)前準(zhǔn)備(5
    的頭像 發(fā)表于 10-21 16:59 ?639次閱讀
    用 <b class='flag-5'>Python</b> 給 Amazon 做“全身 CT”——可量產(chǎn)、可擴(kuò)展的商品詳情<b class='flag-5'>爬蟲(chóng)</b>實(shí)戰(zhàn)

    從 0 到 1:用 PHP 爬蟲(chóng)優(yōu)雅地拿下京東商品詳情

    PHP 語(yǔ)言 實(shí)現(xiàn)一個(gè) 可運(yùn)行的京東商品爬蟲(chóng) ,不僅能抓取商品標(biāo)題、價(jià)格、圖片、評(píng)價(jià)數(shù),還能應(yīng)對(duì)常見(jiàn)的反爬策略。全文附完整代碼, 復(fù)制粘貼即可運(yùn)行 。 一、為什么選擇 PHP 做爬蟲(chóng)? 雖然 Python
    的頭像 發(fā)表于 09-23 16:42 ?1086次閱讀
    從 0 到 1:用 PHP <b class='flag-5'>爬蟲(chóng)</b>優(yōu)雅地拿下京東商品詳情

    Nginx限流與防爬蟲(chóng)配置方案

    在互聯(lián)網(wǎng)業(yè)務(wù)快速發(fā)展的今天,網(wǎng)站面臨著各種流量沖擊和惡意爬蟲(chóng)的威脅。作為運(yùn)維工程師,我們需要在保證正常用戶(hù)訪(fǎng)問(wèn)的同時(shí),有效防范惡意流量和爬蟲(chóng)攻擊。本文將深入探討基于Nginx的限流與防爬蟲(chóng)解決方案,從原理到實(shí)踐,為大家提供一套完
    的頭像 發(fā)表于 09-09 15:52 ?1103次閱讀

    termux如何搭建python游戲

    termux如何搭建python游戲 Termux搭建Python游戲開(kāi)發(fā)環(huán)境的完整指南 一、Termux基礎(chǔ)環(huán)境準(zhǔn)備 Termux是一款無(wú)需root即可在安卓設(shè)備上運(yùn)行的Linux終端
    發(fā)表于 08-29 07:06

    python app不能運(yùn)行怎么解決?

    ;python_agent[1241]: xmlrpc request method supervisor.stopProcess failed;python_agent[1241]: xmlrpc request method supervisor.stopProces
    發(fā)表于 08-06 06:27

    夢(mèng)墨電能檢測(cè)模塊在教學(xué)場(chǎng)景中的應(yīng)用

    工程訓(xùn)練中心的電工電子實(shí)驗(yàn)室里,學(xué)生們正圍著一臺(tái)風(fēng)能發(fā)電裝置進(jìn)行調(diào)試。他們手中的黑色小方盒正實(shí)時(shí)顯示著電流以及電壓的波動(dòng)數(shù)據(jù)--這是夢(mèng)墨電能檢測(cè)模塊在教學(xué)場(chǎng)景中的應(yīng)用。夢(mèng)墨自主研發(fā)并推出的電能檢測(cè)
    的頭像 發(fā)表于 06-19 15:04 ?967次閱讀
    夢(mèng)<b class='flag-5'>之</b>墨電能檢測(cè)<b class='flag-5'>模塊</b>在教學(xué)場(chǎng)景中的應(yīng)用
    工布江达县| 云安县| 汕头市| 陕西省| 金门县| 西平县| 清镇市| 灵川县| 信宜市| 曲靖市| 玛纳斯县| 平江县| 东山县| 大埔县| 时尚| 宜兰市| 托里县| 大安市| 塔河县| 咸阳市| 浮山县| 广汉市| 讷河市| 台北县| 丹江口市| 茶陵县| 石屏县| 易门县| 乌审旗| 门头沟区| 东宁县| 阆中市| 石首市| 和林格尔县| 阿勒泰市| 张掖市| 台南县| 兰西县| 永仁县| 满洲里市| 忻州市|