簡體   English   中英

我收到類似 AttributeError: 'NoneType' object has no attribute 'text' 的錯誤

[英]I am getting error like AttributeError: 'NoneType' object has no attribute 'text'

import pandas as pd

import requests

from bs4 import BeautifulSoup

page = requests.get('https://www.adityaispat.com/vision-mission.html', verify=False)

#url = "https://www.aarti-industries.com/csr/"

#page = requests.get(url)

soup = BeautifulSoup(page.text, 'html.parser')

print(soup.find(class_="text").text) 

or

print(soup.find('td', attrs={'class': 'text'}).text)

對您的問題的簡單回答是find()方法返回類型為 NoneType 的NoneType並且您正在嘗試從中讀取text 為了防止這種情況,首先檢查find()是否給出任何結果是值得的。

result = soup.find(class_="text")
if result:
    print(result.text)
else
    # other action

另一個答案是問題:你想找到什么? 也許您的 class 和/或搜索屬性定義不正確。

我在你的情況下,問題的真正根源是request部分。 如果您檢查page.status_code ,您會注意到它返回 406,這意味着請求不成功。 基於此解決方案,您需要使用不同的用戶代理。 還要記得檢查請求是否成功。 Siplme 方法是使用ok屬性。

page = requests.get('https://www.adityaispat.com/vision-mission.html', headers={"User-Agent": "XY"})
if page.ok:
    print('Request OK!')
    # process the page
else:
    print('Request Failed!')

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM