m0_60026349 2021-08-06 14:39 采纳率: 66.7%
浏览 66
已结题

为什么这个python代码只能抓取豆瓣top250最后一页的内容


import requests
import re
#爬取十个页面
url="https://movie.douban.com/top250?start={}"
for i in range(10):
    start = i * 25
    a = url.format(start)
    headers={"user-agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.107 Safari/537.36 Edg/92.0.902.55"}
    r=requests.get(a,headers=headers)
    b=r.text
# 解析网页
obj=re.compile(r'<li>.*?<div class="item">.*?<span class="title">(?P<name>.*?)</span>',re.S)
result=obj.finditer(b)
for it in result:
     print(it.group("name"))
  • 写回答

2条回答 默认 最新

  • Roc-xb 后端领域优质创作者 2021-08-06 14:48
    关注

    因为解析语句没有在for循环当中,下面这样就可以
    有帮助,望采纳!

    #!/usr/bin/python
    # -*- coding: UTF-8 -*-
    """
    @author: YangPC
    @QQ:327844761
    @微信公众号:ewbang
    """
    
    import requests
    import re
    
    # 爬取十个页面
    url = "https://movie.douban.com/top250?start={}"
    for i in range(10):
        start = i * 25
        a = url.format(start)
        headers = {
            "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.107 Safari/537.36 Edg/92.0.902.55"}
        r = requests.get(a, headers=headers)
        b = r.text
        # 解析网页
        obj = re.compile(r'<li>.*?<div class="item">.*?<span class="title">(?P<name>.*?)</span>', re.S)
        result = obj.finditer(b)
        for it in result:
            print(it.group("name"))
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 8月14日
  • 已采纳回答 8月6日
  • 创建了问题 8月6日

悬赏问题

  • ¥50 微信聊天记录备份到电脑提示成功了,但还是没同步到电脑微信
  • ¥15 python怎么在已有视频文件后添加新帧
  • ¥20 虚幻UE引擎如何让多个同一个蓝图的NPC执行一样的动画,
  • ¥15 fluent里模拟降膜反应的UDF编写
  • ¥15 MYSQL 多表拼接link
  • ¥15 关于某款2.13寸墨水屏的问题
  • ¥15 obsidian的中文层级自动编号
  • ¥15 同一个网口一个电脑连接有网,另一个电脑连接没网
  • ¥15 神经网络模型一直不能上GPU
  • ¥20 wpf datagrid单元闪烁效果失灵