Skip to content
Related Articles

Related Articles

Python | Tools in the world of Web Scraping
  • Difficulty Level : Medium
  • Last Updated : 03 May, 2018

Web page scraping can be done using multiple tools or using different frameworks in Python. There are variety of options available for scraping data from a web page, each suiting different needs.

First, let’s understand the difference between web-scraping and web-crawling. Web crawling is used to index the information on the page using bots also known as Crawlers. On the other hand, Web-scraping is an automated way of extracting the information/content using bots also known as Scrapers.

Let see some most commonly used web Scraping tools for Python3 :

  1. Urllib2
  2. Requests
  3. BeautifulSoup
  4. Lxml
  5. Selenium
  6. MechanicalSoup

Among all the available frameworks/ tools, only urllib2 come pre-installed with Python. So all other tools need to be installed, if needed. Let’s discuss all these tools in detail.

  1. Urllib2 : Urllib2 is a python module used for fetching URL’s. It offers a very simple interface, in the form of urlopen function, which is capable of fetching URL’s using different protocols like HTTP, FTP etc.

    # Using urllib2 module
    from urllib.request import urlopen
    html = urlopen("")

    Output :

  2. Requests : Requests does not come pre-installed with Python. Requests allows to send HTTP/1.1 requests. One can add headers, form data, multipart files and parameters with simple Python dictionaries and access the response data in the same way.

    Installing requests can be done using pip.

    pip install requests

    # Using requests module
    import requests
    # get URL
    req = requests.get('')

    Output :

  3. BeautifulSoup : Beautiful soup is a parsing library that can use different parsers. Beautiful Soup’s default parser comes from Python’s standard library. It creates a parse tree that can be used to extract data from HTML; a toolkit for dissecting a document and extracting what you need. It automatically converts incoming documents to Unicode and outgoing documents to UTF-8.

    pip can be used to install BeautifulSoup :

    pip install beautifulsoup4

    # importing BeautifulSoup form
    # bs4 module
    from bs4 import BeautifulSoup
    # importing requests
    import requests
    # get URL
    r = requests.get("")
    data = r.text
    soup = BeautifulSoup(data)
    for link in soup.find_all('a'):

    Output :

  4. Lxml : Lxml is a high-performance, production-quality HTML and XML parsing library. If the user need speed, then go for Lxml. Lxml has many modules and one of the module is etree , which is responsible for creating elements and structure using these elements.

    One can start using lxml by installing it as a python package using pip tool :

    pip install lxml

    # importing etree from lxml module
    from lxml import etree
    root_elem = etree.Element('html')
    etree.SubElement(root_elem, 'head')
    etree.SubElement(root_elem, 'title')
    etree.SubElement(root_elem, 'body')
    print(etree.tostring(root_elem, pretty_print = True).decode("utf-8"))

    Output :

  5. Selenium : Some websites use javascript to serve content. For example, they might wait until you scroll down on the page or click a button before loading certain content. For these websites, selenium is needed. Selenium is a tool that automates browsers, also known as web-drivers. It also comes with Python bindings for controlling it right from your application.

    pip package is used to install selenium :

    pip install selenium

    # importing webdriver from selenium module
    from selenium import webdriver
    # path for chromedriver
    path_to_chromedriver ='/Users/Admin/Desktop/chromedriver'
    browser = webdriver.Chrome(executable_path = path_to_chromedriver)

    Output :

  6. MechanicalSoup : MechanicalSoup is a Python library for automating interaction with websites. It automatically stores and sends cookies, follows redirects, and can follow links and submit forms. It doesn’t do JavaScript.

    One can use following command to install MechanicalSoup :

    pip install MechanicalSoup

    # importing mechanicalsoup
    import mechanicalsoup
    browser = mechanicalsoup.StatefulBrowser()
    value ="")
    value1 = browser.get_url()
    value2 = browser.follow_link("forms")
    value = browser.get_url()
  7. Scrapy : Scrapy is an open source and collaborative web crawling framework for extracting the data needed from websites. It was originally designed for web scraping. It can be used to manage requests, preserve user sessions follow redirects and handle output pipelines.

    There are 2-methods to install scrapy :

    1. Using pip :
      pip install scrapy
    2. Using Anaconda : First install Anaconda or Miniconda and then use following command to install scrapy :
      conda install -c conda-forge scrapy

    # importing scrapy module
    import scrapy
    class GeeksSpider(scrapy.Spider):
        name = "geeks_spider"
        start_urls = ['']
        # Parse function
        def parse(self, response):
            SET_SELECTOR = 'geeks'
            for geek in response.css(SET_SELECTOR):

    Use following command to run a scrapy code :

    scrapy runspider

    Output :GfGscrapy

Above discussed module are most commonly used scrappers for Python3. Although there are few more but no longer compatible with Python3 like Mechanize, Scrapemark.

References :


Attention geek! Strengthen your foundations with the Python Programming Foundation Course and learn the basics.

To begin with, your interview preparations Enhance your Data Structures concepts with the Python DS Course.

My Personal Notes arrow_drop_up
Recommended Articles
Page :