鱼C论坛

 找回密码
 立即注册
查看: 2051|回复: 4

[已解决]python爬虫豆瓣250部电影出现indexError

[复制链接]
发表于 2021-1-20 16:48:59 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 猛男必看 于 2021-1-20 16:50 编辑

各位大神们好,在学习小甲鱼的爬虫实例。出现了两个错误,一是在运行时,红色代码出现了IndexError: list index out of range。第二个错误是紫色代码出现了TypeError: 'NoneType' object is not iterable。新手上路,还请多多指教
import requests
import bs4
import re
def open_url(url):
    headers={'Host':'movie.douban.com',
            'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.106 Safari/537.36'}
    res=requests.get(url,headers=headers)
    return res
def find_movies(res):
    soup=bs4.BeautifulSoup(res.text,'html.parser')
    movies=[]
    targets=soup.find_all('div',class_='hd')
    for each in targets:
        movies.append(each.a.span.text)
    ranks=[]
    targets=soup.find_all('span',class_='rating_num')
    for each in targets:
        ranks.append('评分:%s'%each.text)
    messages=[]
    targets=soup.find_all('div',class_='bd')
    for each in targets:
        try:
            messages.append(each.p.text.split('\n')[1].srtip()+each.p.text.split('\n')[2].strip())
        except:
            continue
    length=len(movies)
    result=[]
    for i in range(length):
        result.append(movies[i]+ranks[i]+messages[i]+'\n')
    return result

def find_depth(res):
    soup=bs4.BeautifulSoup(res.text,'html.parser')
    depth=soup.find('span',class_='next').previous_sibling.previous_sibling.text
    return int(depth)
def main():
    host='https://movie.douban.com/top250'
    res=open_url(host)
    depth=find_depth(res)
    result=[]
    for i in range(depth):
        url=host+'/?start='+str(25*i)
        res=open_url(url)
        result.extend(find_movies(res))
    with open('豆瓣TOP250电影.txt','w',encoding='utf-8') as f:
        for each in result:
            f.write(each)
if __name__=='__main__':
    main()
最佳答案
2021-1-23 21:49:02
import requests
from lxml import etree


def main():
    url = 'https://movie.douban.com/top250'
    headers = {'user-agent': 'firefox'}
    params = {'start': ''}
    movies = []
    for x in range(10):
        params['start'] = x
        r = requests.get(url, headers=headers, params=params)
        html = etree.HTML(r.text)
        lis = html.xpath('//ol[@class="grid_view"]/li')
        for li in lis:
            m_name = li.xpath('.//div[@class="hd"]/a/span[1]/text()')[0]
            m_rank = li.xpath('.//div[@class="pic"]/em/text()')[0]
            m_score = li.xpath('.//div[@class="star"]/span[2]/text()')[0]
            m_info = li.xpath('normalize-space(.//div[@class="bd"]/p/text())')
            movies.append([m_name, m_rank, m_score, m_info])
    print(movies)


if __name__ == '__main__':
    main()
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-1-20 17:38:25 | 显示全部楼层
红色部分的代码是那样的吗?也许你想说的是result.append(movies[i]+ranks[i]+messages[i]+'\n'),message列表是空列表
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-20 20:47:00 | 显示全部楼层
代码贴出来的时候用代码块包一下啊,这代码怎么看啊。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-1-22 15:31:38 | 显示全部楼层
EthanHsiung 发表于 2021-1-20 17:38
红色部分的代码是那样的吗?也许你想说的是result.append(movies+ranks+messages+'\n'),message列表是空列 ...

没错,是这样的,我往里复制代码的时候,中括号和里面的内容死活复制不上去了,不知道为啥
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-23 21:49:02 | 显示全部楼层    本楼为最佳答案   
import requests
from lxml import etree


def main():
    url = 'https://movie.douban.com/top250'
    headers = {'user-agent': 'firefox'}
    params = {'start': ''}
    movies = []
    for x in range(10):
        params['start'] = x
        r = requests.get(url, headers=headers, params=params)
        html = etree.HTML(r.text)
        lis = html.xpath('//ol[@class="grid_view"]/li')
        for li in lis:
            m_name = li.xpath('.//div[@class="hd"]/a/span[1]/text()')[0]
            m_rank = li.xpath('.//div[@class="pic"]/em/text()')[0]
            m_score = li.xpath('.//div[@class="star"]/span[2]/text()')[0]
            m_info = li.xpath('normalize-space(.//div[@class="bd"]/p/text())')
            movies.append([m_name, m_rank, m_score, m_info])
    print(movies)


if __name__ == '__main__':
    main()
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-16 18:46

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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