python - pyspider翻页问题?

 jerry613 发布于 2022-10-25 09:10

想要爬取爱卡汽车的每个汽车的口碑,但是在翻页问题总是进不去,无论是用chorme还是自带的css selector helper抓取到的CSS PATH都无法翻页,请求帮助,代码如下

#!/usr/bin/env python
# -*- encoding: utf-8 -*-
# Created on 2017-03-21 12:57:03
# Project: test03
import re
from pyspider.libs.base_handler import *


class Handler(BaseHandler):
    crawl_config = {
    }

    @every(minutes=24 * 60)
    def on_start(self):
        self.crawl('http://newcar.xcar.com.cn/price/', callback=self.index_page)

    @config(age=10 * 24 * 60 * 60)
    def index_page(self, response):
        for each in response.doc('a[href^="http"]').items():
            if re.match("http://newcar.xcar.com.cn/\d", each.attr.href, re.U): 
                self.crawl(each.attr.href, callback=self.list_page)
    def list_page(self, response):
        for each in response.doc('body > p.demio_wp > p > ul > li:nth-child(6) > a').items():
            self.crawl(each.attr.href, callback=self.list_page1)
    
    def list_page1(self, response):
        for each in response.doc('.review_gml_tit > .more').items():
            self.crawl(each.attr.href, callback=self.detail_page)
         #翻页,问题出在下面这里
        for each in response.doc('body > p.review_main > p.review_left > p > p.review_comments > p.review_comments_dl > p.pagers > a:nth-child(2)').items():
            self.crawl(each.attr.href, callback=self.list_page1)
            
    @config(priority=2)
    def detail_page(self, response):
        return {
            "branch":response.doc('#nav_ps > em > a').text(),
            "text":response.doc('body > p.review_main > p.review_left > p > p.review_comments > p.review_comments_dl > dl > dd').text(),
           
        }
1 个回答
  • 评论是 javascript 加载的。

    2022-10-26 22:59 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有