鱼C论坛

 找回密码
 立即注册
查看: 1989|回复: 3

[已解决]爬下html的元素之后想要获取其中的超链接报错了

[复制链接]
发表于 2022-6-30 18:41:31 | 显示全部楼层 |阅读模式

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

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

x
问题:解析一段网址元素后内容如下:
<h4><a href="https://research.com/u/pierre-bourdieu" title="Read more">Pierre Bourdieu</a></h4>


<span class="sh">Collège de France,
France</span>

需要获取其中的超链接内容

代码如下
for result in soup.find_all('span', class_="col col--5 col--tablet"):
    for nameUrl in result:
        print(nameUrl.get('href'))

结果报错
AttributeError: 'NavigableString' object has no attribute 'get'

请教一下各位这个是什么问题?

最佳答案
2022-6-30 18:45:52

nameUrl.get('href') 改成 nameUrl.href

直接 .href 试试,报错显示 NavigableString 没有 get 属性

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-6-30 18:45:52 | 显示全部楼层    本楼为最佳答案   

nameUrl.get('href') 改成 nameUrl.href

直接 .href 试试,报错显示 NavigableString 没有 get 属性

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

使用道具 举报

 楼主| 发表于 2022-6-30 19:08:30 | 显示全部楼层
Twilight6 发表于 2022-6-30 18:45
nameUrl.get('href') 改成 nameUrl.href

直接 .href 试试,报错显示 NavigableString 没有 get 属性

用了您的方法报错变成:
AttributeError: 'NavigableString' object has no attribute 'href'

看了下数据对象的类型是
<class 'bs4.element.NavigableString'>
<class 'bs4.element.Tag'>
这两种
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-6-30 19:19:12 | 显示全部楼层
这里自己回一下吧,问题解决了,主要就是在find_all()之后返回的对象仍然是tag对象,从这个地方入手,就是考虑怎么解析和提取tag对象里的元素,找了一下资料后代码改成
for result in soup.find_all('span', class_="col col--5 col--tablet"):
    nameUrl=result.a['href']
就ok了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-6-30 01:00

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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