0

我最近问了这个关于在 BeautifulSoup 中编码印地语字符的问题。该问题的答案确实解决了该问题,但是我还有另一个问题。

我的代码是:

import urllib2
from bs4 import BeautifulSoup

htmlUrl = "http://archives.ndtv.com/articles/2012-01.html"
FileName = "NDTV_2012_01.txt"

fptr = open(FileName, "w")
fptr.seek(0)

page = urllib2.urlopen(htmlUrl)
soup = BeautifulSoup(page, from_encoding="UTF-8")

li = soup.findAll( 'li')
for link_tag in li:
  hypref = link_tag.find('a').contents[0]
  strhyp = hypref.encode('utf-8')
  fptr.write(strhyp)
  fptr.write("\n")

我得到一个错误

Traceback (most recent call last):
File "./ScrapeTemplate.py", line 29, in <module>
hypref = link_tag.find('a').contents[0]
IndexError: list index out of range

当我替换print strhyp而不是fptr.write(). 我该如何解决?

编辑:代码中有一个我没有发现的错误。修复了它,但我仍然遇到同样的错误。

4

2 回答 2

1

您的错误的原因与写入文件没有任何关系。link_tag.find('a').contents当您尝试获取第一项时,似乎有时会返回一个空列表并给出错误。你可以尝试这样的事情:

for link_tag in li:
    try:
        hypref = link_tag.find('a').contents[0]
    except IndexError:
        print link_tag #print link tag where it couldn't extract the 'a'
        continue
    strhyp = hypref.encode('utf-8')
    fptr.write(strhyp)
    fptr.write("\n")
于 2013-01-19T10:26:36.227 回答
1

您的代码绊倒了页面底部的链接。跳过这些:

for link_tag in li:
  contents = link_tag.find('a').contents
  if len(contents) > 0:
    hypref = contents[0]
    strhyp = hypref.encode('utf-8')
    fptr.write(strhyp)
    fptr.write("\n")
于 2013-01-19T10:54:09.220 回答