首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >TypeError:'NoneType‘对象不可调用(NoneType:从NoneType数据中抓取)

TypeError:'NoneType‘对象不可调用(NoneType:从NoneType数据中抓取)
EN

Stack Overflow用户
提问于 2015-12-21 04:18:57
回答 1查看 505关注 0票数 1

我试图从HTML数据中提取数字,以便得到它们的总和。但是,当我试图运行它时,我遇到了上述错误。它指的是"data =“行。在这一行代码中,这个错误指的是什么?我是否正确地设置了"for“循环?谢谢你的想法。

代码语言:javascript
复制
import urllib
from bs4 import BeautifulSoup

url = "http://python-data.dr-chuck.net/comments_42.html"
html = urllib.urlopen(url).read()

soup = BeautifulSoup(html, "html.parser")
tags = soup('span')
data = soup.findall("span", {"Comments":"Comments"})
numbers = [d.text for d in data]

summation = 0
for tag in tags:
    print tags
    y= tag.finall("span").text      
    summation = summation + int(y)                  
print summation

--这就是HTML的样子:

代码语言:javascript
复制
<tr><td>Modu</td><td><span class="comments">90</span></td></tr>
<tr><td>Kenzie</td><td><span class="comments">88</span></td></tr>
<tr><td>Hubert</td><td><span class="comments">87</span></td></tr>
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-12-21 04:21:50

首先,在findall()中没有BeautifulSoup方法--有find_all()。此外,您基本上是在搜索具有Comments属性的具有Comments值的元素:

代码语言:javascript
复制
soup.findall("span", {"Comments":"Comments"})  

而且,这是Python,您可以更容易地用一个sum()来总结。

固定版本:

代码语言:javascript
复制
data = soup.find_all("span", {"class": "comments"})
print sum(int(d.text) for d in data)  # prints 2482
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34388900

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档