ホームページ >ウェブフロントエンド >jsチュートリアル >NodejsでWebサイトの画像をクロールする方法

NodejsでWebサイトの画像をクロールする方法

亚连
亚连オリジナル
2018-06-20 16:40:052799ブラウズ

nodejs を使用してウェブサイトの画像をクロールする方法をサンプルを通して説明しますので、興味のある方は保存してください。

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

原則:

クローラーは、明らかに I/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));
    })
    
  })
})

以上が私がやった内容です皆様向けにまとめましたので、今後皆様のお役に立てれば幸いです。

関連記事:

jsで再代入を実装する方法

キャンバスで生成した画像をjsで保存する方法

jsで双方向バインディングを実装する方法

より実践的な機能を紹介webpackの詳細

jQueryを使用したメニューの追加と削除機能の実装方法

nodejs+mongodb+vueを使用したueditorの設定方法

以上がNodejsでWebサイトの画像をクロールする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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