se-scraper/run.js

76 lines
2.8 KiB
JavaScript
Raw Normal View History

2018-12-24 14:25:02 +01:00
const se_scraper = require('./index.js');
let config = {
// the user agent to scrape with
user_agent: 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.110 Safari/537.36',
// if random_user_agent is set to True, a random user agent is chosen
2019-01-27 20:08:09 +01:00
random_user_agent: true,
2018-12-24 14:25:02 +01:00
// how long to sleep between requests. a random sleep interval within the range [a,b]
// is drawn before every request. empty string for no sleeping.
sleep_range: '',
2018-12-24 14:25:02 +01:00
// which search engine to scrape
search_engine: 'baidu',
2018-12-24 14:25:02 +01:00
// whether debug information should be printed
2019-01-27 15:54:56 +01:00
// debug info is useful for developers when debugging
2019-01-30 23:53:09 +01:00
debug: false,
2018-12-24 14:25:02 +01:00
// whether verbose program output should be printed
2019-01-27 15:54:56 +01:00
// this output is informational
2019-01-30 16:05:08 +01:00
verbose: true,
2018-12-24 14:25:02 +01:00
// an array of keywords to scrape
keywords: ['cat', 'mouse'],
// alternatively you can specify a keyword_file. this overwrites the keywords array
2019-01-26 20:15:19 +01:00
keyword_file: '',
// the number of pages to scrape for each keyword
2019-03-10 20:02:42 +01:00
num_pages: 1,
// whether to start the browser in headless mode
2019-03-10 20:02:42 +01:00
headless: false,
2019-01-26 20:15:19 +01:00
// path to output file, data will be stored in JSON
output_file: 'examples/results/baidu.json',
// whether to prevent images, css, fonts from being loaded
// will speed up scraping a great deal
2019-03-10 20:02:42 +01:00
block_assets: false,
2019-01-27 15:54:56 +01:00
// path to js module that extends functionality
// this module should export the functions:
// get_browser, handle_metadata, close_browser
// must be an absolute path to the module
//custom_func: resolve('examples/pluggable.js'),
custom_func: '',
// use a proxy for all connections
// example: 'socks5://78.94.172.42:1080'
// example: 'http://118.174.233.10:48400'
2019-01-30 23:53:09 +01:00
proxy: '',
// a file with one proxy per line. Example:
// socks5://78.94.172.42:1080
// http://118.174.233.10:48400
proxy_file: '',
// check if headless chrome escapes common detection techniques
// this is a quick test and should be used for debugging
test_evasion: false,
2019-03-10 20:02:42 +01:00
apply_evasion_techniques: true,
// log ip address data
log_ip_address: false,
// log http headers
log_http_headers: false,
puppeteer_cluster_config: {
timeout: 10 * 60 * 1000, // max timeout set to 10 minutes
monitor: false,
concurrency: 1, // one scraper per tab
maxConcurrency: 1, // scrape with 2 tabs
}
2018-12-24 14:25:02 +01:00
};
2019-01-27 20:08:09 +01:00
function callback(err, response) {
2018-12-24 14:25:02 +01:00
if (err) { console.error(err) }
/* response object has the following properties:
response.results - json object with the scraping results
response.metadata - json object with metadata information
response.statusCode - status code of the scraping process
*/
console.dir(response.results, {depth: null, colors: true});
2019-01-27 20:08:09 +01:00
}
se_scraper.scrape(config, callback);