鱼C论坛

 找回密码
 立即注册
查看: 1347|回复: 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")定制属性查找?

  1. import urllib.request
  2. from bs4 import BeautifulSoup
  3. import re
  4. from urllib.parse import quote


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

  9. soup = BeautifulSoup(html,"html.parser")
  10. result = soup.find_all(itemprop="dateUpdate")#就是这儿
  11. for each in result:
  12.     print(each)
复制代码


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


name是这个方法的默认参数

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

  2. sb = soup.find_all('img')
复制代码


你的第二个result = soup.find_all(name="description") beautifulsoup就认为是查找名为description的标签,也就找不到,所以只能构造result = soup.find_all(attrs={"name":"description")来查找
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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


name是这个方法的默认参数

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

  2. sb = soup.find_all('img')
复制代码


你的第二个result = soup.find_all(name="description") beautifulsoup就认为是查找名为description的标签,也就找不到,所以只能构造result = soup.find_all(attrs={"name":"description")来查找
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

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

name的使用

秒懂
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-25 23:05

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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