chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Python爬蟲之Beautiful Soup模塊

電子設計 ? 來源:電子設計 ? 作者:電子設計 ? 2020-12-10 21:56 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

模塊安裝

pip3 install beautifulsoup4

模塊導入

from bs4 import BeautifulSoup

示例html內容

獲取html內容代碼

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內容


小說排行榜列表

構建BeautifulSoup對象

常用四種解釋器

解釋器 標識 特點
Python標準庫 html.parser Python內置,執(zhí)行速度中
lxml的HTML解釋器 lxml 速度快
lxml的XML解釋器 xml 唯一支持XML解析
html5lib html5lib 容錯性最好,以瀏覽器方式解析
soup = BeautifulSoup(html, 'html.parser')

還可以解析本地html文件

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

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

通過 . 獲取節(jié)點

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

結果是

對于名稱唯一的節(jié)點,可以省略層級

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

結果同樣是

名稱不唯一的節(jié)點,直接獲取只會獲取第一個匹配的節(jié)點

li = soup.li
print(li)

結果是

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

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

根據(jù)標簽名字

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

結果是

根據(jù)標簽屬性

屬性和值以字典形式傳入

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

結果是
作品名稱
我能舉報萬物
女戰(zhàn)神的黑包群
花崗巖之怒
超神機械師
無量真途
我的細胞監(jiān)獄
前任無雙
元陽道君
逆成長巨星
承包大明

限制搜索范圍

find_all 方法會搜索當前標簽的所有子孫節(jié)點,如果只想搜索直接子節(jié)點,可以使用參數(shù) recursive=False

遍歷獲取子節(jié)點

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

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

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

結果是
['/n',

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

返回一個list生成器對象

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

結果是
['/n', 

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

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

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

獲取其父節(jié)點

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

結果是
首頁

提取節(jié)點信息

節(jié)點名稱

感覺沒什么用

title = soup.title
print(title.name)

結果是
title

節(jié)點屬性

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

結果是
首頁
{'href': '/'}
/

節(jié)點文本

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

首頁

注意?。?!如果節(jié)點內文本是注釋,則用string取出文本時會自動去除注釋標記
注釋的類型:,可以通過類型判斷

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

for string in soup.stripped_strings:  # 去除多余空白內容
    print(repr(string))
想進一步了解編程開發(fā)相關知識,與我一同成長進步,請關注我的公眾號“松果倉庫”,共同分享宅&程序員的各類資源,謝謝!??!

審核編輯 黃昊宇
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • JAVA
    +關注

    關注

    20

    文章

    2989

    瀏覽量

    109771
  • 人工智能
    +關注

    關注

    1807

    文章

    49029

    瀏覽量

    249579
  • python
    +關注

    關注

    56

    文章

    4827

    瀏覽量

    86766
  • 爬蟲
    +關注

    關注

    0

    文章

    83

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    墨電能檢測模塊在教學場景中的應用

    工程訓練中心的電工電子實驗室里,學生們正圍著一臺風能發(fā)電裝置進行調試。他們手中的黑色小方盒正實時顯示著電流以及電壓的波動數(shù)據(jù)--這是夢墨電能檢測模塊在教學場景中的應用。夢墨自主研發(fā)并推出的電能檢測
    的頭像 發(fā)表于 06-19 15:04 ?341次閱讀
    夢<b class='flag-5'>之</b>墨電能檢測<b class='flag-5'>模塊</b>在教學場景中的應用

    爬蟲數(shù)據(jù)獲取實戰(zhàn)指南:從入門到高效采集

    爬蟲數(shù)據(jù)獲取實戰(zhàn)指南:從入門到高效采集 ? ? 在數(shù)字化浪潮中,數(shù)據(jù)已成為驅動商業(yè)增長的核心引擎。無論是市場趨勢洞察、競品動態(tài)追蹤,還是用戶行為分析,爬蟲技術都能助你快速捕獲目標信息。然而,如何既
    的頭像 發(fā)表于 03-24 14:08 ?623次閱讀

    運行OVModelForCausalLM Python模塊時出錯了,怎么解決?

    創(chuàng)建了一個自定義 Python* 代碼,類似于遵循 240-dolly-2-instruction 的 Jupyter 筆記本。 OVModelForCausalLM Python* 模塊運行時出錯。
    發(fā)表于 03-05 06:44

    Python繪圖Matplotlib快速參考手冊

    ?PYTHON
    發(fā)表于 02-07 14:04 ?0次下載

    使用Python實現(xiàn)xgboost教程

    使用Python實現(xiàn)XGBoost模型通常涉及以下幾個步驟:數(shù)據(jù)準備、模型訓練、模型評估和模型預測。以下是一個詳細的教程,指導你如何在Python中使用XGBoost。 1. 安裝XGBoost
    的頭像 發(fā)表于 01-19 11:21 ?1383次閱讀

    IP地址數(shù)據(jù)信息和爬蟲攔截的關聯(lián)

    IP地址數(shù)據(jù)信息和爬蟲攔截的關聯(lián)主要涉及到兩方面的內容,也就是數(shù)據(jù)信息和爬蟲。IP 地址數(shù)據(jù)信息的內容豐富,包括所屬地域、所屬網絡運營商、訪問時間序列、訪問頻率等。 從IP地址信息中可以窺見
    的頭像 發(fā)表于 12-23 10:13 ?384次閱讀

    Python常用函數(shù)大全

    Python 世界里,有一些寶藏函數(shù)和模塊,它們可以讓你編程更輕松、代碼更高效。這篇文章將帶你一一認識這些神器,讓你的開發(fā)生活瞬間輕松不少!
    的頭像 發(fā)表于 10-27 17:20 ?919次閱讀

    全球視野下的海外爬蟲IP:趨勢、機遇與風險

    在全球視野下,海外爬蟲IP的使用呈現(xiàn)出一系列趨勢,同時也伴隨著機遇與風險。
    的頭像 發(fā)表于 10-15 07:54 ?540次閱讀

    海外爬蟲IP的合法邊界:合規(guī)性探討與實踐

    海外爬蟲IP的合法邊界主要涉及合規(guī)性探討與實踐。
    的頭像 發(fā)表于 10-12 07:56 ?611次閱讀

    如何利用海外爬蟲IP進行數(shù)據(jù)抓取

    利用海外爬蟲IP進行數(shù)據(jù)抓取需要綜合考慮多個方面。
    的頭像 發(fā)表于 10-12 07:54 ?599次閱讀

    詳細解讀爬蟲多開代理IP的用途,以及如何配置!

    爬蟲多開代理IP是一種在爬蟲開發(fā)中常用的技術策略,主要用于提高數(shù)據(jù)采集效率、避免IP被封禁以及獲取地域特定的數(shù)據(jù)。
    的頭像 發(fā)表于 09-14 07:55 ?813次閱讀

    pytorch和python的關系是什么

    在當今的人工智能領域,Python已經成為了最受歡迎的編程語言之一。Python的易學易用、豐富的庫和框架以及強大的社區(qū)支持,使其成為了數(shù)據(jù)科學、機器學習和深度學習等領域的首選語言。而在深度學習領域
    的頭像 發(fā)表于 08-01 15:27 ?3284次閱讀

    EtherCAT運動控制器上位機Python+Qt(一):鏈接與單軸運動

    PC上位機Python+Qt混合編程,助力智能制造高效開發(fā)。
    的頭像 發(fā)表于 07-31 09:43 ?864次閱讀
    EtherCAT運動控制器上位機<b class='flag-5'>之</b><b class='flag-5'>Python</b>+Qt(一):鏈接與單軸運動

    Python建模算法與應用

    Python作為一種功能強大、免費、開源且面向對象的編程語言,在科學計算、數(shù)學建模、數(shù)據(jù)分析等領域展現(xiàn)出了卓越的性能。其簡潔的語法、對動態(tài)輸入的支持以及解釋性語言的本質,使得Python在多個平臺
    的頭像 發(fā)表于 07-24 10:41 ?1274次閱讀

    Python在AI中的應用實例

    Python在人工智能(AI)領域的應用極為廣泛且深入,從基礎的數(shù)據(jù)處理、模型訓練到高級的應用部署,Python都扮演著至關重要的角色。以下將詳細探討Python在AI中的幾個關鍵應用實例,包括機器學習、深度學習、自然語言處理、
    的頭像 發(fā)表于 07-19 17:16 ?2709次閱讀