Python爬虫报错(属性报错):AttributeError: ‘NoneType‘ object has no attribute ‘children‘

Python爬虫报错:AttributeError: ‘NoneType’ object has no attribute ‘children’

近期,有很多小伙伴问我在爬虫过程中遇到的一个问题AttributeError: ‘NoneType’ object has no attribute ‘children’,通过查询后也没有找到较好的解决方法。本文给大家提供一个解决方案。

爬取网页示例

网站:产业信息网
图片示例:在这里插入图片描述

代码

Created on Fri Jan 20 11:30:31 2023

@author: 北辰远_code

I love python.快乐每一天!
"""
import requests
from bs4 import BeautifulSoup
import bs4
import csv

def getHTMLText(url):#爬取网站数据
    try:
        r = requests.get(url, timeout = 30)
        r.raise_for_status()
        r.encoding = r.apparent_encoding
        return r.text
    except:
        return '爬取失败'

def fillUnivlist(ulist,html):#解析网站数据
    soup = BeautifulSoup(html,"html.parser") 
    for tr in soup.find('tbody').children:
        if isinstance(tr,bs4.element.Tag):
            tds = tr('td')
            ulist.append([tds[0].text,tds[1].text,tds[2].text,tds[3].text,tds[4].text,tds[5].text,tds[6].text,tds[7].text])

def writeUlistfile(ulist,dataname):#将网站存入csv文件
    with open(dataname,'w',encoding = 'utf-8',newline='') as fout:
        writer = csv.writer(fout)
        for row in ulist:
            writer.writerow(row)
            
url1 = 'https://www.chyxx.com/industry/202105/953391.html'
html1 = getHTMLText(url1)
uinfo1 =[]
fillUnivlist(uinfo1,html1)
writeUlistfile(uinfo1,'各种油产量初.csv')

报错

Traceback (most recent call last):
  File "D:\Users\Qi520503\Desktop\shiyou\未命名3.py", line 45, in <module>
    fillUnivlist(uinfo1,html1)
  File "D:\Users\Qi520503\Desktop\shiyou\未命名3.py", line 29, in fillUnivlist
    for tr in soup.find('tbody').children:
AttributeError: 'NoneType' object has no attribute 'children'

解决方案:
加入urllib3模块,关闭ssl警告。
在这里插入图片描述

代码如下:

import requests
from bs4 import BeautifulSoup
import bs4
import csv
import urllib3
urllib3.disable_warnings()

def getHTMLText(url):#爬取网站数据
    try:
        r = requests.get(url, timeout = 30,verify=False)
        r.raise_for_status()
        r.encoding = r.apparent_encoding
        return r.text
    except:
        return '爬取失败'

运行后无报错,爬取的数据正常保存在csv文件中。在这里插入图片描述

这个错误信息表示在使用'NoneType'对象时,尝试访问它没有的'ray_aabb_intersect'属性。根据提供的引用内容,无法直接确定问题的具体原因,因为错误信息中未提及该属性的来源。然而,根据其中的两个引用,这个错误通常与对象的类型或属性的匹配问题有关。 根据引用,在重新训练模型时出现此错误可能是因为数据采集过程中得到的数据为None,导致模型训练过程中无法计算数据的形状。这可能需要检查数据采集的过程是否有问题,或者检查模型训练代码中是否正确处理了None值。 根据引用,在运行嵩天老师的Python爬虫课程中的一个实例时出现此错误,错误信息中提到的'NoneType'对象的'children'属性可能是指爬虫过程中获取的网页元素对象中没有'children'属性。这可能需要检查代码中对网页元素对象的处理逻辑,以确保在访问对象的属性之前进行必要的有效性检查。 除了上述引用中提到的错误原因外,根据引用,另一个可能的原因是读取的图片内容与默认读取参数不匹配。例如,如果读取的图片是灰度图而默认读取参数是针对彩色图像的,就可能返回None。这种情况下,可以尝试根据实际情况调整读取参数,以确保读取的图片与参数匹配。 综上所述,出现AttributeError: 'NoneType' object has no attribute 'ray_aabb_intersect'错误可能是由于对象类型或属性的匹配问题引起的。您需要根据具体情况检查代码中与该属性相关的部分,并确保正确处理了None值,或者进行参数调整以匹配实际数据。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [AttributeError:NoneTypeobject has no attribute ‘shape](https://blog.youkuaiyun.com/weixin_38809962/article/details/126966598)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [AttributeError:NoneTypeobject has no attributechildren’ 错误](https://download.youkuaiyun.com/download/weixin_38502292/13743883)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

北辰远_code

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值