首頁  >  文章  >  web前端  >  nodejs實作爬取網站圖片功能_node.js

nodejs實作爬取網站圖片功能_node.js

韦小宝
韦小宝原創
2017-12-16 09:15:532084瀏覽

給大家透過一個實例來教學如何用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));
    })
    
  })
})
以上就是本文的所有內容,希望會為小夥伴帶來幫助! !

相關推薦:

#NodeJS爬蟲實例之糗事百科_node.js

#NodeJs之關於資料庫異常處理的解決方法

#如何用nodejs實作聊天功能

##

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

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