ホームページ  >  記事  >  ウェブフロントエンド  >  nodejsはWebサイトをクローリングする機能を実装しますimages_node.js

nodejsはWebサイトをクローリングする機能を実装しますimages_node.js

韦小宝
韦小宝オリジナル
2017-12-16 09:15:532021ブラウズ

nodejs を使用して Web サイト 画像 をクロールする機能を実装する方法を説明する例を示します。興味のある友達はそれを保存できます。

nodejs が Web サイトの画像をクロールする機能を実装する方法を例を通して説明します。以下にその全内容を示します。

原則:

Crawler は、明らかに IO 集中型のアプリケーション シナリオです。 /O待機オーバーヘッド 小さなデータマイニングの方が便利です

Expressモジュールを使用してノードサービスを構築し

、Requestモジュールを使用してターゲットページのHTMLコードを取得します

HTMLコードを処理するためにcheerioモジュールをダウンロードします(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はWebサイトをクローリングする機能を実装しますimages_node.jsの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。