首頁 >web前端 >js教程 >在nodejs中如何實作爬取網站圖片

在nodejs中如何實作爬取網站圖片

亚连
亚连原創
2018-06-20 16:40:052770瀏覽

給大家透過一個實例來教學如何用nodejs實現爬取網站圖片功能,有興趣的朋友收藏一下吧。

透過實例跟大家講解nodejs實作爬取網站圖片功能,以下就是全部:

原理:

##爬蟲是最明顯的IO密集型應用場景,顯然用node,使得I/O等待開銷小數據挖掘比較方便

借助express模組來搭建node服務

並使用request模組獲取目標頁面的html代碼

下載cheerio模組對html程式碼做處理(cheerio類似jQuery的語法,所以好用又方便)

環境設定:

npm install express request cheerio --save

#(1)引入各個模組

var http = require('http');
var request = require('request);
var cheerio = require('cheerio');
var fs = require('fs'); //用来操作文件
var url = 'https://movie.douban.com/cinema/nowplaying/beijing/' //定义要爬的页面

(2)發送請求

http.get(function(res){
  var html = '';
  var titles = [];
  res.setEncoding('utf-8') //防止中文乱码
  res.on('data',function(chunk){
    html += chrunk;    //监听data事件 每次取一块数据
  })
  res.on('end',function(){
    var $ = cheerio.load(html);  //获取数据完成后,解析html
    //将获取的图片存到images文件夹中
    $('.mod-bd img').each(function(index, item){
      //获取图片属性
      var imgName = $(this).parent().next().text().trimg()
      var imgfile = imgName + '.jpeg';
      var imgSrc = $(this).attr('src')
      //采用request模块,向服务器发起请求 获取图片资源
      request.head(imgSrc, function(error, res,body){
        if(error){
          console.log('失败了')
        }
      });
      //通过管道的方式用fs模块将图片写到本地的images文件下
      request(imgSrc).pipe.(fs.createWriteStream('./images/' + imgfile));
    })
    
  })
})

上面是我整理給大家的,希望今後會對大家有幫助。

相關文章:

使用js如何實作從新賦值

###在js中如何將canvas產生圖片儲存##### #######在js中如何實現雙向綁定############詳細介紹webpack比較實用功能############使用jQuery如何實作選單新增移除功能############使用nodejs mongodb vue如何設定ueditor######

以上是在nodejs中如何實作爬取網站圖片的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn