爬虫AttributeError: 'NoneType' object has no attribute 'find' 的问题

问题遇到的现象和发生背景

AttributeError: 'NoneType' object has no attribute 'find'

问题相关代码,请勿粘贴截图

for i in main1:
son1 = i.get("href") # 可以直接通过get获取里面内容的值
# 进入href子页面取源代码
son2 = requests.get("http://bizhi360.com/"+son1)
son2.encoding='utf-8'
# 拿到子页面图片的下载途径
son_page = BeautifulSoup(son2.text, "html.parser")
son_tu = son_page.find("figure")
print(son_tu)
a = son_tu.find("a")

运行结果及报错内容

没有a = son_tu("a")的时候可以正常打印son_tu,里面也有a标签,但是有了a = son_tu("a")之后son_tu结果就是None了

我想要达到的结果

想要知道怎么解决,才能是程序正常运行

你这个代码是在循环中多次执行的
你不是每次循环 son_page中都有figure标签,
第一次循环 son_page中就没有figure标签, son_tu = son_page.find("figure") 返回None
第二次循环 son_page中才有figure标签

没有a = son_tu("a")的时候,第一次循环 打印son_tu结果就是None,第二次循环 打印son_tu才是正常的div
加a = son_tu("a")的时候,第一次循环 son_tu结果是None, 用None调用find()会出错结束程序了,也就不会有第二次循环了

img

首先发表我的见解:son_page返回的应该是一个对象,但是你的son_tu(即son_page.find)返回的可能是一个NoneType对象。是不是应将a=son_tu.find("a")改为a=son_page.find("a")?

你的代码是在循环里执行的
你确定循环里每个son_tu都有a标签吗
只要有一个没有,就要报错
你需要在执行find之前先做非空判断,不要拿None去执行find

你看看你正常打印的son_tu里面有a标签嘛?

给你找了一篇非常好的博客,你可以看看是否有帮助,链接:求解决AttributeError: ‘NoneType‘ object has no attribute ‘find_all‘问题