【问题标题】:Crawling hidden data using Scrapy使用 Scrapy 抓取隐藏数据
【发布时间】:2015-07-03 13:02:30
【问题描述】:

我刚开始爬。我正在尝试通过使用 Scrapy 框架和 Python 2.7 下载内容来从网站 http://www.indiabix.com/verbal-ability/spotting-errors/ 抓取问题和答案。我注意到,如果您查看其来源,您会注意到每个问题的答案都应该在 b 标签中,但不是:

<div class="div-spacer">
   <p><span class="ib-green"><b>Answer:</b></span> Option <b class="jq-hdnakqb"></b></p> 
   <p><span class="ib-green"><b>Explanation:</b></span></p> 
   <p> No answer description available for this question. <b><a href="discussion-399">Let us discuss</a></b>. </p>

如果我们检查网页上的元素,我们可以在标签之间的文本中看到正确的答案:答案:每个问题的选项 A 或 B 等,但 HTML 源代码没有。

为了获得 b 标记中的文本,我使用 xpath 尝试了大约 15 个查询。 我在下面的代码中将最可能的 4-5 个查询编写为 cmets。

import scrapy
import urllib
import json
from errors1.items import Errors1Item

class Errors1Spider(scrapy.Spider) :
    name = "errors1"
    start_urls =  ["http://www.indiabix.com/verbal-ability/spotting-errors/"]

    def parse(self, response) :
        i = 0
        y = 0
        j = json.loads(json.dumps(response.xpath('//td[contains(@id, "tdOption")]/text()').extract()))
        x = json.loads(json.dumps(response.xpath('//div[@class="div-spacer"]/p[3]/text()').extract()))

        #to get correct answer
        #response.xpath('//div[@class = "div-spacer"]/p/b/text()').extract()
        #response.xpath('//div[@class = "div-spacer"]/p[1]/b/text()').extract()
        #response.xpath('//div[@class = "div-spacer"]/p//text()').extract()
        #response.xpath('//b[@class = "jq-hdnakqb"]/text()').extract()
        #response.xpath('string(//div[@class = "div-spacer"]/p/b/text())').extract()

        while i<len(j) and y<len(x) :
            item = Errors1Item()
            item['optionA'] = j[i]
            i+=1 
            item['optionB'] = j[i]
            i+=1 
            item['optionC'] = j[i]
            i+=1 
            item['optionD'] = j[i]
            i+=1 
            item['explanation'] = x[y]
            y+=1
            yield item

有人可以帮我从该网页获取答案内容吗? 谢谢

【问题讨论】:

    标签: python python-2.7 xpath web-scraping scrapy


    【解决方案1】:

    据我了解,设置正确的选项值涉及到 javascript 逻辑。

    帮助我解决它的是scrapyjs middleware,它使用Splash browser-as-a-service。跳过安装和配置,这是我执行的蜘蛛:

    # -*- coding: utf-8 -*-
    import scrapy
    
    
    class IndiaBixSpider(scrapy.Spider):
        name = "indiabix"
        allowed_domain = ["www.indiabix.com"]
        start_urls = ["http://www.indiabix.com/verbal-ability/spotting-errors/"]
    
        def start_requests(self):
            for url in self.start_urls:
                yield scrapy.Request(url, meta={
                    'splash': {
                        'endpoint': 'render.html',
                        'args': {'wait': 0.5}
                    }
                })
    
        def parse(self, response):
            for question in response.css("div.bix-div-container"):
                answer = question.xpath(".//input[starts-with(@id, 'hdnAnswer')]/@value").extract()
                print answer
    

    这是我在控制台上得到的(正确答案):

    [u'A']
    [u'C']
    [u'A']
    [u'C']
    [u'C']
    [u'C']
    [u'B']
    [u'A']
    [u'D']
    [u'C']
    [u'B']
    [u'B']
    [u'A']
    [u'B']
    [u'B']
    

    另见:

    【讨论】:

    • 我试图运行这个完全相同的代码,但我仍然没有得到任何输出并且我得到一个空集。我想我可能配置错了。你能把你的 settings.py 文件发给我吗?
    • @pratibha 它们与链接答案中的完全相同。另外,请确保启动程序正在运行。
    猜你喜欢
    • 2020-11-26
    • 2019-06-18
    • 1970-01-01
    • 2013-05-23
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多