scrapeteer v1.0.4
Scrapeteer
Scrapeteer is a NodeJS library for web-scraping using Puppeteer.
Installation
Use the package manager npm to install Scrapeteer.
npm install scrapeteerUsage
Scrapeteer will extract data from an web-page using an array of objects where which one will represent rules of how to fetch and store data in the returning object.
import Scrapeteer from 'scrapeteer';
const defaultTagsConfig = [
  {
    saveAs: 'title',
    query: 'title',
    attrsToFetch: ['innerHTML'],
  },
];
const onRequestTagsConfig = [
  {
    saveAs: 'title',
    query: 'title',
    attrsToFetch: ['innerHTML'],
  },
  {
    saveAs: 'image',
    query: 'meta[name="og:image"], meta[property="og:image"]',
    attrsToFetch: ['content'],
  },
];
const scrapeteer = new Scrapeteer(defaultTagsConfig);
(async () => {
  await scrapeteer.launch();
  const withDefault = await scrapeteer.extractFromUrl('http://amazon.com');
  const withOnRequest = await scrapeteer.extractFromUrl(
    'http://amazon.com',
    onRequestTagsConfig
  );
  console.log('With default tags config: ', withDefault);
  console.log('With OnRequest tags config: ', withOnRequest);
})();To prepare Scrapeteer for use is necessary to follow a sequence of steps:
- Load Scrapeteer Class.
- Instantiate it. Is possible to set predefined tag rules here, but is optional.
- Call the asyncmethod.start()which will load puppeteer with optimized settings.
Tags Config:
const tagsConfig = [
  {
    saveAs: 'title',
    query: 'meta[name="og:title"], meta[property="og:title"]',
    attrsToFetch: ['content'],
  },
  {
    saveAs: 'image',
    query: 'meta[name="og:image"], meta[property="og:image"]',
    attrsToFetch: ['content'],
  },
];An object with tag rules are defined by three parameters:
- saveAs: A string that represents the key in the returning object. 
- query: A string that will be used in a document.querySelectorAll during the scraping. 
- attrsToFetch: A array containing all the attributes to fetch from the html tags resulting from the query. 
Scrapeteer will use what's defined in the query to fetch html tags, going one by one of the resulting list and get the value from each attribute requested in attrsToFetch. After that it will store everything that was found into an array of strings and save in the resulting object by a key named as the saveAs value.
It goes by the sequence: Fetch a tag by query -> Get values from Attributes -> Add to resulting object as defined
You execute the async method .extractFromUrl to extract the data from a url. A set of tag rules can be used as a second parameter which will be used stead of the default one.
const withDefault = await scrapeteer.extractFromUrl('http://amazon.com') // Goes with default
const withOnRequest = await scrapeteer.extractFromUrl('http://amazon.com', onRequestTagsConfig)The return will be an object with your scraped data. In case of no set of tag rules defined, the return will be an empty object.
{
 "title": [
   "Here it comes an result",
   "here it comes another result",
 ],
 "image": [
   "http://imagine_a_image_here.png",
   "http://imagine_another_image_here.png",
   "http://imagine_one_more_image_here.png",
 ],
 "author": [] // empty array means no data was extracted from this set of tag rules
}Contributing
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.
Please make sure to update tests as appropriate.