ホームページ >ウェブフロントエンド >jsチュートリアル >nodejsはWebサイトをクローリングする機能を実装しますimages_node.js
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はWebサイトをクローリングする機能を実装しますimages_node.jsの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。