您好,欢迎来到UU财经。
搜索
您的当前位置:首页在nodejs中如何实现爬取网站图片

在nodejs中如何实现爬取网站图片

来源:UU财经


给大家通过一个实例来教学如何用nodejs实现爬取网站图片功能,有兴趣的朋友收藏一下吧。

通过实例给大家讲解nodejs实现爬取网站图片功能,以下就是全部内容:

原理:

爬虫是最明显的IO密集型应用场景,显然用node,使得I/O等待开销小数据挖掘比较方便

借助express模块来搭建node服务

并使用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));
 })
 
 })
})

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

使用js如何实现从新赋值

在js中如何将canvas生成图片保存

在js中如何实现双向绑定

详细介绍webpack比较实用功能

使用jQuery如何实现菜单添加移除功能

使用nodejs+mongodb+vue如何配置ueditor

Copyright © 2019- uude.cn 版权所有

违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务