中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

BeautifulSoup的四大對象種類是什么

發布時間:2020-09-24 10:13:08 來源:億速云 閱讀:258 作者:Leah 欄目:編程語言

BeautifulSoup的四大對象種類是什么?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

四大對象種類

Beautiful Soup將復雜HTML文檔轉換成一個復雜的樹形結構,每個節點都是Python對象,所有對象可以歸納為4種:

(1)Tag

(2)NavigableString

(3)BeautifulSoup

(4)Comment

1. Tag

Tag 通俗點講就是 HTML 中的一個個標簽,例如:

from bs4 import BeautifulSoup
html = """
<div>
    <ul>
         <li class="item-0"><a href="link1.html">first item</a></li>
         <li class="item-1"><a href="link2.html">second item</a></li>
         <li class="item-inactive"><a href="link3.html"><span class="bold">third item</span></a></li>
         <li class="item-1"><a href="link4.html">fourth item</a></li>
         <li class="item-0"><a href="link5.html">fifth item</a></li>
     </ul>
 </div>
"""
# 創建 Beautiful Soup 對象
soup = BeautifulSoup(html, "lxml")
print(soup.li)  # <li class="item-0"><a href="link1.html">first item</a></li>
print(soup.a)  # <a href="link1.html">first item</a>
print(soup.span)  # <span class="bold">third item</span>
print(soup.p)  # None
print(type(soup.li))  # <class 'bs4.element.Tag'>

我們可以利用 soup 加標簽名輕松地獲取這些標簽的內容,這些對象的類型是bs4.element.Tag。但是注意,它查找的是在所有內容中的第一個符合要求的標簽。如果要查詢所有的標簽,后面會進行介紹。

對于 Tag,它有兩個重要的屬性,是name和attrs。

from bs4 import BeautifulSoup
html = """
<div>
    <ul>
         <li class="item-0"><a href="link1.html">first item</a></li>
         <li class="item-1"><a href="link2.html">second item</a></li>
         <li class="item-inactive"><a href="link3.html"><span class="bold">third item</span></a></li>
         <li class="item-1"><a href="link4.html">fourth item</a></li>
         <li class="item-0"><a href="link5.html">fifth item</a></li>
     </ul>
 </div>
"""
# 創建 Beautiful Soup 對象
soup = BeautifulSoup(html, "lxml")
print(soup.li.attrs)  # {'class': ['item-0']}
print(soup.li["class"])  # ['item-0']
print(soup.li.get('class'))  # ['item-0']
print(soup.li)  # <li class="item-0"><a href="link1.html">first item</a></li>
soup.li["class"] = "newClass"  # 可以對這些屬性和內容等等進行修改
print(soup.li)  # <li class="newClass"><a href="link1.html">first item</a></li>
del soup.li['class']  # 還可以對這個屬性進行刪除
print(soup.li)  # <li><a href="link1.html">first item</a></li>

2. NavigableString

既然我們已經得到了標簽的內容,那么問題來了,我們要想獲取標簽內部的文字怎么辦呢?很簡單,用 .string 即可,例如

from bs4 import BeautifulSoup
html = """
<div>
    <ul>
         <li class="item-0"><a href="link1.html">first item</a></li>
         <li class="item-1"><a href="link2.html">second item</a></li>
         <li class="item-inactive"><a href="link3.html"><span class="bold">third item</span></a></li>
         <li class="item-1"><a href="link4.html">fourth item</a></li>
         <li class="item-0"><a href="link5.html">fifth item</a></li>
     </ul>
 </div>
"""
# 創建 Beautiful Soup 對象
soup = BeautifulSoup(html, "lxml")
print(soup.li.string)  # first item
print(soup.a.string)  # first item
print(soup.span.string)  # third item
# print(soup.p.string)  # AttributeError: 'NoneType' object has no attribute 'string'
print(type(soup.li.string))  # <class 'bs4.element.NavigableString'>

3. BeautifulSoup

BeautifulSoup 對象表示的是一個文檔的內容。大部分時候,可以把它當作 Tag 對象,是一個特殊的 Tag,我們可以分別獲取它的類型,名稱,以及屬性來感受一下。

from bs4 import BeautifulSoup
html = """
<div>
    <ul>
         <li class="item-0"><a href="link1.html">first item</a></li>
         <li class="item-1"><a href="link2.html">second item</a></li>
         <li class="item-inactive"><a href="link3.html"><span class="bold">third item</span></a></li>
         <li class="item-1"><a href="link4.html">fourth item</a></li>
         <li class="item-0"><a href="link5.html">fifth item</a></li>
     </ul>
 </div>
"""
# 創建 Beautiful Soup 對象
soup = BeautifulSoup(html, "lxml")
print(soup.name)  # [document]
print(soup.attrs)  # {}, 文檔本身的屬性為空
print(type(soup.name))  # <class 'str'>

4. Comment

Comment 對象是一個特殊類型的 NavigableString 對象,其輸出的內容不包括注釋符號。

from bs4 import BeautifulSoup
 
html = """
<div>
   <a class="sister" href="http://example.com/elsie" id="link1"><!-- Elsie --></a>
</div>
"""
 
# 創建 Beautiful Soup 對象
soup = BeautifulSoup(html, "lxml")

print(soup.a)  # <a class="sister" href="http://example.com/elsie" id="link1"><!-- Elsie --></a>
print(soup.a.string)  # Elsie 
print(type(soup.a.string))  # <class 'bs4.element.Comment'>

a 標簽里的內容實際上是注釋,但是如果我們利用 .string 來輸出它的內容時,注釋符號已經去掉了。

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

安塞县| 阜新| 阿克陶县| 石城县| 太谷县| 石棉县| 林甸县| 金山区| 固原市| 平邑县| 门头沟区| 怀集县| 昌平区| 天长市| 高州市| 新竹市| 新乐市| 阿拉善盟| 东兰县| 西乡县| 柯坪县| 玛纳斯县| 准格尔旗| 庆安县| 梅河口市| 崇左市| 保靖县| 信阳市| 大余县| 包头市| 陇川县| 鹤壁市| 沁源县| 镇远县| 南昌市| 新竹县| 宁阳县| 南开区| 砀山县| 丽江市| 历史|