鱼C论坛

 找回密码
 立即注册
查看: 1119|回复: 2

[已解决]find_all()

[复制链接]
发表于 2020-8-21 07:35:25 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
1.result = soup.find_all(itemprop="dateUpdate")
2.result = soup.find_all(name="description")
为什么第一个可以查找出来,第二个就不行,只能result = soup.find_all(attrs={"name":"description")定制属性查找?
import urllib.request
from bs4 import BeautifulSoup
import re
from urllib.parse import quote


url = f'http://baike.baidu.com/item/{quote("百度")}/6699'
response = urllib.request.urlopen(url)
html = response.read()
html = html.decode("utf-8")

soup = BeautifulSoup(html,"html.parser")
result = soup.find_all(itemprop="dateUpdate")#就是这儿
for each in result:
    print(each)

QQ图片20200821073342.png
最佳答案
2020-8-21 09:14:27
find_all( name , attrs , recursive , string , **kwargs ) 
find_all() 方法搜索当前tag的所有tag子节点,并判断是否符合过滤器的条件

name是这个方法的默认参数

name的使用
这是最简单而直接的一种办法了,我么可以通过html标签名来索引;

sb = soup.find_all('img')

你的第二个result = soup.find_all(name="description") beautifulsoup就认为是查找名为description的标签,也就找不到,所以只能构造result = soup.find_all(attrs={"name":"description")来查找
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-8-21 09:14:27 | 显示全部楼层    本楼为最佳答案   
find_all( name , attrs , recursive , string , **kwargs ) 
find_all() 方法搜索当前tag的所有tag子节点,并判断是否符合过滤器的条件

name是这个方法的默认参数

name的使用
这是最简单而直接的一种办法了,我么可以通过html标签名来索引;

sb = soup.find_all('img')

你的第二个result = soup.find_all(name="description") beautifulsoup就认为是查找名为description的标签,也就找不到,所以只能构造result = soup.find_all(attrs={"name":"description")来查找
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2020-8-21 11:18:56 | 显示全部楼层
1q23w31 发表于 2020-8-21 09:14
name是这个方法的默认参数

name的使用

秒懂
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-19 07:52

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表