在nodejs中如何实现爬取网站图片
程序员文章站
2022-04-07 10:42:00
...
给大家通过一个实例来教学如何用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)); }) }) })
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
使用nodejs+mongodb+vue如何配置ueditor
以上就是在nodejs中如何实现爬取网站图片的详细内容,更多请关注其它相关文章!
上一篇: 使用jquery如何实现定位式导航
下一篇: php实现数组指针操作详解
推荐阅读
-
nodejs实现爬取网站图片功能
-
如何爬取天堂网1920*1080大图片并实现批量下载
-
Python实现Office自动化办公(实现Python对word基本操作、对excel基本操作、在word中插入表格、word中插入网站爬虫取图)
-
在cropper中js通过vue的图片裁剪上传功能如何实现
-
在vue中如何实现剪裁图片并上传服务器功能
-
在nodejs中如何实现爬取网站图片
-
小弟我用ci框架,实现了图片的上传,但当小弟我删除的时候,并没有在文档中删除掉图片,小弟我需要如何做
-
在JS中如何实现非首屏图片延迟加载
-
nodejs实现爬取网站图片功能_node.js
-
小弟我用ci框架,实现了图片的上传,但当小弟我删除的时候,并没有在文档中删除掉图片,小弟我需要如何做