Scrapy Splash不会执行lua脚本

时间:2016-08-12 00:46:16

标签: scrapy scrapy-spider splash scrapy-splash

我遇到过我的Lua脚本拒绝执行的问题。 ScrapyRequest调用返回的响应似乎是一个HTML主体,而我期待一个文档标题。我假设从未调用Lua脚本,因为它似乎对响应没有明显影响。我通过文档挖了很多东西,似乎无法弄清楚这里缺少什么。有没有人有任何建议?

from urlparse import urljoin

import scrapy
from scrapy_splash import SplashRequest


GOOGLE_BASE_URL = 'https://www.google.com/'
GOOGLE_QUERY_PARAMETERS = '#q={query}'
GOOGLE_SEARCH_URL = urljoin(GOOGLE_BASE_URL, GOOGLE_QUERY_PARAMETERS)

GOOGLE_SEARCH_QUERY = 'example search query'


LUA_SCRIPT = """
function main(splash)
    assert(splash:go(splash.args.url))
    return splash:evaljs("document.title")
end
"""

SCRAPY_CRAWLER_NAME = 'google_crawler'
SCRAPY_SPLASH_ENDPOINT = 'render.html'
SCRAPY_ARGS = {
    'lua_source': LUA_SCRIPT
}


def get_search_url(query):
    return GOOGLE_SEARCH_URL.format(query=query)


class GoogleCrawler(scrapy.Spider):
    name=SCRAPY_CRAWLER_NAME
    search_url = get_search_url(GOOGLE_SEARCH_QUERY)

    def start_requests(self):

        response = SplashRequest(self.search_url,
            self.parse, endpoint=SPLASH_ENDPOINT, args=SCRAPY_ARGS)

        yield response


    def parse(self, response):
        doc_title = response.body_as_unicode()
        print doc_title

2 个答案:

答案 0 :(得分:3)

SplashRequest的

'endpoint'参数必须是'execute'才能执行Lua脚本;它是示例中的'render.html'。

答案 1 :(得分:1)

 LUA_SCRIPT = """
    function main(splash)
      assert(splash:go(splash.args.url))
      return title = splash:evaljs("document.title")
    end
    """

 def start_requests(self):

   SplashRequest(self.search_url,self.parse, endpoint='execute',args=SCRAPY_ARGS)

您可以使用response.data['title']

恢复该值