scrape a website's content.
npm i -g mega-scraper
mega-scraper https://www.wikipedia.org
-
running redis instance on host 0.0.0.0 port 6379
-
on debian/ubuntu, install additional required libraries via
sudo apt install -y gconf-service libasound2 libatk1.0-0 libc6 libcairo2 libcups2 libdbus-1-3 libexpat1 libfontconfig1 libgcc1 libgconf-2-4 libgdk-pixbuf2.0-0 libglib2.0-0 libgtk-3-0 libnspr4 libpango-1.0-0 libpangocairo-1.0-0 libstdc++6 libx11-6 libx11-xcb1 libxcb1 libxcomposite1 libxcursor1 libxdamage1 libxext6 libxfixes3 libxi6 libxrandr2 libxrender1 libxss1 libxtst6 ca-certificates fonts-liberation libappindicator1 libnss3 lsb-release xdg-utils wget
see api.md for more usage example and options.
e.g.
(async () => {
const {browser: {createBrowser, takeScreenshot}, queue: {createQueue}} = require('.')
const browser = await createBrowser()
const queue = createQueue('wikipedia')
const page = await browser.newPage('https://www.wikipedia.org/')
const url = 'https://www.wikipedia.org/'
await queue.add({ url })
queue.process(async (job) => {
await page.goto(job.data.url)
await takeScreenshot(page, job.data)
const content = await page.content()
console.log('content', content.substring(0, 500))
})
})()
set to false
to run the scraper in "headful" mode (non-headless)
e.g.
mega-scraper https://www.wikipedia.org --headless false
set to false
to avoid taking a screenshot of each scraped page
e.g.
mega-scraper https://www.wikipedia.org --headless false
set to false
to avoid proxying each request through a free proxy service (currently the module get-free-https-proxy
is used)
e.g.
mega-scraper https://www.wikipedia.org --proxy false
set the timeout to a desired number in milliseconds (5000 = 5 seconds)
e.g.
mega-scraper https://www.wikipedia.org --timeout 10000
set to false
to avoid loading images
e.g.
mega-scraper https://www.wikipedia.org --images false
set to false
to avoid loading stylesheets
e.g.
mega-scraper https://www.wikipedia.org --stylesheets false
set to false
to avoid loading javascript
e.g.
mega-scraper https://www.wikipedia.org --javascript false
set to false
to avoid opening the web dashboard on localhost:4000
e.g.
mega-scraper https://www.wikipedia.org --monitor false
set to true
to exit the program with success or failure status code once done scraping.
e.g.
mega-scraper https://www.wikipedia.org --exit
set to a desired cookie to further prevent detection
e.g.
mega-scraper https://www.wikipedia.org --cookie 'my=cookie'