亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

添加 .text 屬性時出現 AttributeError

添加 .text 屬性時出現 AttributeError

互換的青春 2023-07-18 17:31:44
我已經嘗試過下面的腳本,它工作得很好:from bs4 import BeautifulSoupimport requests pr= input("search: ")source= requests.get('https://www.flipkart.com/search?q={}&otracker=search&otracker1=search&marketplace=FLIPKART&as-show=on&as=off'.format(pr)).contentsoup = BeautifulSoup(source, 'html.parser')url= soup.find_all('div', class_=('_3O0U0u'))whole_product_list= []whole_url_list= []main_product_list= []main_url_list= []        for i in url:    tag_a_data= i.find_all('a')    for l in tag_a_data:        product_list= l.find('div', class_= '_3wU53n')        if product_list:            main_product_list.append(product_list.text)        else:            product_ok= l.get('title')            main_product_list.append(product_ok)print(main_product_list) 例如,如果我傳遞“samsung”作為輸入,它會返回具有給定類 ID 的可用屬性“div”的列表,該屬性作為參數傳遞,如果我傳遞其他內容作為輸入,例如具有“title”的“shoes”屬性它返回 html 中所有可用標題的列表。但如果我顛倒順序,如下所示:from bs4 import BeautifulSoupimport requests pr= input("search: ")source= requests.get('https://www.flipkart.com/search?q={}&otracker=search&otracker1=search&marketplace=FLIPKART&as-show=on&as=off'.format(pr)).contentsoup = BeautifulSoup(source, 'html.parser')url= soup.find_all('div', class_=('_3O0U0u'))whole_product_list= []whole_url_list= []main_product_list= []main_url_list= []        for i in url:    tag_a_data= i.find_all('a')    for l in tag_a_data:        product_list = l.get('title')                if product_list:            main_product_list.append(product_list)        else:            product_ok= l.find('div', class_= '_3wU53n').text            main_product_list.append(product_ok)    print(main_product_list)它開始給出屬性錯誤:Traceback (most recent call last):  File "tess.py", line 28, in <module>    product_ok= l.find('div', class_= '_3wU53n').textAttributeError: 'NoneType' object has no attribute 'text'我不明白為什么第一個腳本基于 if-else 操作運行良好,但第二個腳本卻不能。
查看完整描述

2 回答

?
慕雪6442864

TA貢獻1812條經驗 獲得超5個贊

在這一行中:

product_ok= l.find('div', class_= '_3wU53n').text

l.find('div', class_= '_3wU53n')返回None,意味著它沒有找到 div。None值沒有text屬性,因此會引發AttributeError異常。

解決方法是使用新的 walrus 運算符:

if product_ok := l.find('div', class_= '_3wU53n'):
    product_ok = product_ok.text


查看完整回答
反對 回復 2023-07-18
?
弒天下

TA貢獻1818條經驗 獲得超8個贊

假設您為“l”值收集了以下數據

  • 項目1<title>title1</title><div class_= '_3wU53n'>xyz</div>

  • 項目2<title>title1</title><div>xyz</div>

  • 項目3<title>title1</title><div class_= '_3wU53n'>xyz</div>

使用第一個代碼,您的product_list變量將包含 item1 和 item3。然后您就可以獲取title給定項目的可用信息。所以代碼運行沒有任何問題。

使用第二個代碼,您的product_list變量將包含 item1、item2 和 item3。但在這種情況下,您將無法獲得所需的div標簽,因為第二個項目不存在該標簽。這會導致屬性錯誤。

簡單的事情是數據庫中的項目總是有一個標題,但很可能不會總是有所需的div標簽。

以下更改應該可以使其正常工作:

from bs4 import BeautifulSoup

import requests 


pr= input("search: ")


source= requests.get('https://www.flipkart.com/search?q={}&otracker=search&otracker1=search&marketplace=FLIPKART&as-show=on&as=off'.format(pr)).content

soup = BeautifulSoup(source, 'html.parser')


url= soup.find_all('div', class_=('_3O0U0u'))

whole_product_list= []

whole_url_list= []

main_product_list= []

main_url_list= []

        



for i in url:

    tag_a_data= i.find_all('a')

    for l in tag_a_data:

        product_list = l.get('title')


        


        if product_list:

            main_product_list.append(product_list)


        else:

            if l.find("div", class_='_3wU53n'):

                product_ok= l.find('div', class_= '_3wU53n').text

                main_product_list.append(product_ok)    



print(main_product_list)


查看完整回答
反對 回復 2023-07-18
  • 2 回答
  • 0 關注
  • 177 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號