Skip to content

Latest commit

 

History

History
79 lines (51 loc) · 2.29 KB

README.md

File metadata and controls

79 lines (51 loc) · 2.29 KB

Goodreads quotes scraper

Description

This scraper is straightforward and specifically designed to extract quotes from the Goodreads website. Built in Node.js using the Puppeteer library, it scrapes 100 pages at once, collecting approximately 8,000 records. Each record includes the main quote, the writer's name, and their image. Simply follow the steps provided to set up this project on your local machine, and you can modify and use it as needed.

Table of Contents

Installation

Features

  • Scrapes quotes and image sources from Goodreads quotes pages.
  • Navigates through multiple pages of quotes.
  • Saves the collected data into a CSV file.

Prerequisites

  • Node.js (>=14.0.0)
  • npm (Node Package Manager)
  1. Clone this repository:

    git clone https://github.com/NomanSiddiqui0000/goodreads_quotes-scraper.git
  2. Navigate to the project directory:

    cd goodreads_quotes scraper
  3. Install the required npm packages:

    npm install

Usage

  1. Open the Scraper_script.js file and adjust the maxPages variable if you want to scrape fewer pages. By default, it is set to scrape 100 pages.

  2. Run the script:

    node Scraper_script.js
  3. The script will navigate through the Goodreads quotes pages, scrape quotes and image sources, and save the data to quotes_and_images.csv.

Configuration

  • Puppeteer Launch Options: The script launches Puppeteer in non-headless mode for debugging purposes. Change { headless: false } to { headless: true } if you want to run it in headless mode.
  • CSV File Path: The CSV file will be saved as quotes_and_images.csv in the root directory of the project.

Notes

  • Ensure you comply with Goodreads' terms of service when scraping their website.
  • This script assumes the structure of the Goodreads quotes pages remains consistent. If Goodreads updates their site, you may need to adjust the selectors used in the script.

License

This project is licensed under the MIT License.

Author

Muhammad Noman