第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

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

添加 .text 屬性時出現(xiàn) AttributeError

添加 .text 屬性時出現(xiàn) AttributeError

互換的青春 2023-07-18 17:31:44
我已經(jīng)嘗試過下面的腳本,它工作得很好: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”的列表,該屬性作為參數(shù)傳遞,如果我傳遞其他內(nèi)容作為輸入,例如具有“title”的“shoes”屬性它返回 html 中所有可用標(biāo)題的列表。但如果我顛倒順序,如下所示: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貢獻(xiàn)1812條經(jīng)驗 獲得超5個贊

在這一行中:

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

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

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

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


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

TA貢獻(xiàn)1818條經(jīng)驗 獲得超8個贊

假設(shè)您為“l(fā)”值收集了以下數(shù)據(jù)

  • 項目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標(biāo)簽,因為第二個項目不存在該標(biāo)簽。這會導(dǎo)致屬性錯誤。

簡單的事情是數(shù)據(jù)庫中的項目總是有一個標(biāo)題,但很可能不會總是有所需的div標(biāo)簽。

以下更改應(yīng)該可以使其正常工作:

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)


查看完整回答
反對 回復(fù) 2023-07-18
  • 2 回答
  • 0 關(guān)注
  • 186 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號