給大家透過一個實例來教學如何用nodejs實現爬取網站圖片功能,有興趣的朋友收藏一下吧。
透過實例來講解nodejs實現爬取網站圖片功能,以下就是全部:
原理:
環境設定:
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/' //定义要爬的页面
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之關於資料庫異常處理的解決方法#如何用nodejs實作聊天功能##以上是nodejs實作爬取網站圖片功能_node.js的詳細內容。更多資訊請關注PHP中文網其他相關文章!