La mia soluzione per eseguire più di 200 spider contemporaneamente è stata quella di creare un comando personalizzato per il progetto. Vedere http://doc.scrapy.org/en/latest/topics/commands.html#custom-project-commands per ulteriori informazioni sull'implementazione dei comandi personalizzati.
YourProjectName/comandi/allcrawl.py:
from scrapy.command import ScrapyCommand
import urllib
import urllib2
from scrapy import log
class AllCrawlCommand(ScrapyCommand):
requires_project = True
default_settings = {'LOG_ENABLED': False}
def short_desc(self):
return "Schedule a run for all available spiders"
def run(self, args, opts):
url = 'http://localhost:6800/schedule.json'
for s in self.crawler.spiders.list():
values = {'project' : 'YOUR_PROJECT_NAME', 'spider' : s}
data = urllib.urlencode(values)
req = urllib2.Request(url, data)
response = urllib2.urlopen(req)
log.msg(response)
assicurarsi di includere quanto segue nel settings.py
COMMANDS_MODULE = 'YOURPROJECTNAME.commands'
Poi dalla linea di comando (nella directory del progetto) puoi semplicemente digitare
scrapy allcrawl
Grande, proverò questa prima cosa al mattino. Non ho il computer al momento. Grazie per l'aiuto! – user1009453
Ciao. Ho provato la tua soluzione ma ricevo il seguente errore di importazione: errore di importazione: Nessun modulo chiamato comandi Ho messo la riga "COMMANDS_MODULE = 'YOURPROJECTNAME.commands'" nel file delle impostazioni nella directory del progetto. È corretto? – user1009453
@ user1009453 Assicurati che la tua cartella dei comandi abbia un '__init __. Py' – dru