У меня проблема. Мне нужно некоторое время прекратить выполнение функции, но не останавливать реализацию синтаксического анализа в целом. То есть мне нужна неблокирующая пауза.Scrapy: неблокирующая пауза
Это выглядит следующим образом: должна быть остановлена на некоторое время
class ScrapySpider(Spider):
name = 'live_function'
def start_requests(self):
yield Request('some url', callback=self.non_stop_function)
def non_stop_function(self, response):
for url in ['url1', 'url2', 'url3', 'more urls']:
yield Request(url, callback=self.second_parse_function)
# Here I need some function for sleep only this function like time.sleep(10)
yield Request('some url', callback=self.non_stop_function) # Call itself
def second_parse_function(self, response):
pass
Функция non_stop_function, но он не должен блокировать остальную часть вывода.
Если я вставляю time.sleep()
- он остановит весь синтаксический анализатор, но мне это не нужно. Можно ли остановить одну функцию, используя twisted
или что-то еще?
Причина:: Мне нужно создать неблокирующую функцию, которая будет анализировать страницу сайта каждые n секунд. Там она получит URL-адреса и заполнит 10 секунд. Полученные URL-адреса будут продолжать работать, но основная функция должна спать.
UPDATE:
Благодаря TkTech и Вяч. Один из ответов помог мне понять, как сделать ожидающий Request
, а второй - как его активировать. Оба ответа дополняет друг друг, и я сделал отличную нелипкую паузу Scrapy:
def call_after_pause(self, response):
d = Deferred()
reactor.callLater(10.0, d.callback, Request(
'https://example.com/',
callback=self.non_stop_function,
dont_filter=True))
return d
И использовать эту функцию для моего запроса:
yield Request('https://example.com/', callback=self.call_after_pause, dont_filter=True)
Может ли этот подход помочь? http://stackoverflow.com/questions/37002742/calling-the-same-spider-programmatic/37007619#37007619 –
@ RafaelAlmeida Это не очень удобный способ. Я хочу использовать эту паузу в будущем, не ставя под угрозу архитектуру анализатора. – JRazor
Вы хотите приостановить его, чтобы не сделать запрос? или просто сделать паузу внутри метода? было бы очень полезно, если бы вы могли указать причину этой паузы. – eLRuLL