Sha*_*kai 10

有一个新的框架,只是释放了Node.js的称为蜘蛛.它使用jQuery来抓取/索引网站的HTML页面.API和配置非常好,特别是如果您已经了解jQuery.

从测试套件中,这里是爬行纽约时报网站的一个例子:

var spider = require('../main');

spider()
  .route('www.nytimes.com', '/pages/dining/index.html', function (window, $) {
    $('a').spider();
  })
  .route('travel.nytimes.com', '*', function (window, $) {
    $('a').spider();
    if (this.fromCache) return;

    var article = { title: $('nyt_headline').text(), articleBody: '', photos: [] }
    article.body = '' 
    $('div.articleBody').each(function () {
      article.body += this.outerHTML;
    })
    $('div#abColumn img').each(function () {
      var p = $(this).attr('src');
      if (p.indexOf('ADS') === -1) {
        article.photos.push(p);
      }
    })
    console.log(article);
  })
  .route('dinersjournal.blogs.nytimes.com', '*', function (window, $) {
    var article = {title: $('h1.entry-title').text()}
    console.log($('div.entry-content').html())
  })
  .get('http://www.nytimes.com/pages/dining/index.html')
  .log('info')
  ;
Run Code Online (Sandbox Code Playgroud)


zin*_*del 8

试试PhantomJS.不完全是爬虫,但可以很容易地用于此目的.它具有内置的全功能WebKit引擎,能够保存屏幕截图等.作为简单的命令行JS解释器.