php网页抓取图片(通过一个实例来教学如何用nodejs实现爬取网站图片功能 )
优采云 发布时间: 2021-12-25 12:01php网页抓取图片(通过一个实例来教学如何用nodejs实现爬取网站图片功能
)
通过一个例子教你如何使用nodejs实现爬取网站图片的功能。有兴趣的请采集
。
我将通过例子来说明nodejs是如何实现爬取网站图片的功能的。以下为全文:
原则:
爬虫是最明显的 IO 密集型应用场景。很明显,node是用来让数据挖掘更方便的I/O等待开销。
使用 express 模块构建节点服务
并使用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));
})
})
})