Scrapy Tutorial on Scrapy Command Line Tools

description

the scrapy command line tool is used for controlling scrapy, which is often referred to as 'scrapy tool'. it includes the commands for various objects with a group of arguments and options.

configuration settings

scrapy will find configuration settings in the scrapy.cfg file. following are a few locations −

  • c:\scrapy(project folder)\scrapy.cfg in the system

  • ~/.config/scrapy.cfg ($xdg_config_home) and ~/.scrapy.cfg ($home) for global settings

  • you can find the scrapy.cfg inside the root of the project.

scrapy can also be configured using the following environment variables −

  • scrapy_settings_module
  • scrapy_project
  • scrapy_python_shell

default structure scrapy project

the following structure shows the default file structure of the scrapy project.

scrapy.cfg                - deploy the configuration file
project_name/             - name of the project
   _init_.py
   items.py               - it is project's items file
   pipelines.py           - it is project's pipelines file
   settings.py            - it is project's settings file
   spiders                - it is the spiders directory
      _init_.py
      spider_name.py
      . . .

the scrapy.cfg file is a project root directory, which includes the project name with the project settings. for instance −

[settings] 
default = [name of the project].settings  

[deploy] 
#url = http://localhost:6800/ 
project = [name of the project] 

using scrapy tool

scrapy tool provides some usage and available commands as follows −

scrapy x.y  - no active project 
usage: 
   scrapy  [options] [arguments] 
available commands: 
   crawl      it puts spider (handle the url) to work for crawling data 
   fetch      it fetches the response from the given url

creating a project

you can use the following command to create the project in scrapy −

scrapy startproject project_name

this will create the project called project_name directory. next, go to the newly created project, using the following command −

cd  project_name

controlling projects

you can control the project and manage them using the scrapy tool and also create the new spider, using the following command −

scrapy genspider mydomain mydomain.com

the commands such as crawl, etc. must be used inside the scrapy project. you will come to know which commands must run inside the scrapy project in the coming section.

scrapy contains some built-in commands, which can be used for your project. to see the list of available commands, use the following command −

scrapy -h

when you run the following command, scrapy will display the list of available commands as listed −

  • fetch − it fetches the url using scrapy downloader.

  • runspider − it is used to run self-contained spider without creating a project.

  • settings − it specifies the project setting value.

  • shell − it is an interactive scraping module for the given url.

  • startproject − it creates a new scrapy project.

  • version − it displays the scrapy version.

  • view − it fetches the url using scrapy downloader and show the contents in a browser.

you can have some project related commands as listed −

  • crawl − it is used to crawl data using the spider.

  • check − it checks the items returned by the crawled command.

  • list − it displays the list of available spiders present in the project.

  • edit − you can edit the spiders by using the editor.

  • parse − it parses the given url with the spider.

  • bench − it is used to run quick benchmark test (benchmark tells how many number of pages can be crawled per minute by scrapy).

custom project commands

you can build a custom project command with commands_module setting in scrapy project. it includes a default empty string in the setting. you can add the following custom command −

commands_module = 'mycmd.commands'

scrapy commands can be added using the scrapy.commands section in the setup.py file shown as follows −

from setuptools import setup, find_packages  

setup(name = 'scrapy-module_demo', 
   entry_points = { 
      'scrapy.commands': [ 
         'cmd_demo = my_module.commands:cmddemo', 
      ], 
   }, 
)

the above code adds cmd_demo command in the setup.py file.