Skip to content
A Node.js command line application that goes to an e-commerce site to get the latest prices and saves them to a spreadsheet in CSV format.
Branch: master
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Type Name Latest commit message Commit time
Failed to load latest commit information.

Content Scraper

Project 6 | Treehouse Full Stack JavaScript Techdegree

A Node.js command line application that goes to an e-commerce site to get the latest prices and saves them to a spreadsheet in CSV format.


  • Create a scraper.js file that will contain your command line application. Your project should also include a package.json file that includes your project’s dependencies. The npm install command should install your dependencies.
  • Program your scraper to check for a folder called ‘data’. If the folder doesn’t exist, the scraper should create one. If the folder does exist, the scraper should do nothing.
  • Choose and use two third-party npm packages. One package should be used to scrape content from the site. The other package should create the CSV file. Be sure to research the best package to use (see the project resources for a link to the video about how to choose a good npm package) Both packages should meet the following requirements:
    • At least 1,000 downloads.
    • Has been updated in the last six months.
  • Program your scraper so that it visits the website and uses as single entry point to scrape information for 8 tee-shirts from the site, without using any hard-coded urls like If you’re unsure of how to get started, try googling ‘node scraper’ to get a feel for what a scraper is and what it does.
  • Scraping and Saving Data:
    • The scraper should get the price, title, url and image url from the product page and save this information into a CSV file.
    • The information should be stored in an CSV file that is named for the date it was created, e.g. 2016-11-21.csv.
    • Assume that the the column headers in the CSV need to be in a certain order to be correctly entered into a database. They should be in this order: Title, Price, ImageURL, URL, and Time
    • The CSV file should be saved inside the ‘data’ folder.
  • If your program is run twice, it should overwrite the data in the CSV file with the updated information.
  • If is down, an error message describing the issue should appear in the console.
    • The error should be human-friendly, such as “There’s been a 404 error. Cannot connect to”
    • To test and make sure the error message displays as expected, you can disable the wifi on your computer or device.

Extra Credit

  • Edit your package.json file so that your program runs when the npm start command is run.
  • When an error occurs, log it to a file named scraper-error.log . It should append to the bottom of the file with a time stamp and error e.g. [Tue Feb 16 2016 10:02:12 GMT-0800 (PST)]

View Project


To copy the repository's files from here onto your computer and to view and serve those files locally, at your computer's command line type:

git clone

Open the files in a text editor such as Visual Studio Code and, if you have access to Bash, in the terminal type:

npm install

to install all of the required dependencies. Then type:

npm start

The CSV file will be in a folder named "data".

You can’t perform that action at this time.