我的编程空间,编程开发者的网络收藏夹
学习永远不晚

node.js简单爬虫的方法是什么

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

node.js简单爬虫的方法是什么

这篇文章主要介绍“node.js简单爬虫的方法是什么”,在日常操作中,相信很多人在node.js简单爬虫的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”node.js简单爬虫的方法是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

步骤一:安装node.js

下载并安装node,此步骤比较简单就不详细解释了,有问题的可以直接问一下度娘。

步骤二:建立工程

1)打开dos命令条,cd进入想要创建项目的路径(我将此项目直接放在了E盘,以下皆以此路径为例);

2)mkdir node (创建一个文件夹用来存放项目,我这里取名为node);

3)cd 进入名为node的文件夹,并执行npm init初始化工程(期间会让填写一些信息,我是直接回车的);

步骤三:创建爬取到的数据存放的文件夹

1)创建data文件夹用来存放发型师基本信息;

2)创建image文件夹用来存储发型师头像图片;

  此时工程下文件如下: 

node.js简单爬虫的方法是什么

步骤四:安装第三方依赖包(fs是内置模块,不需要单独安装)

1)npm install cheerio –save

2)npm install superagent –save

3)npm install async –save

4)npm install request –save

分别简单解释一下上面安装的依赖包:

cheerio:是nodejs的抓取页面模块,为服务器特别定制的,快速、灵活、实施的jQuery核心实现,则能够对请求结果进行解析,解析方式和jQuery的解析方式几乎完全相同;

superagent:能够实现主动发起get/post/delete等请求;

async:async模块是为了解决嵌套金字塔,和异步流程控制而生,由于nodejs是异步编程模型,有一些在同步编程中很容易做到的事情,现在却变得很麻烦。Async的流程控制就是为了简化这些操作;

request:有了这个模块,http请求变的超简单,Request使用简单,同时支持https和重定向; 

步骤五:编写爬虫程序代码

打开hz.js,编写代码:

var superagent = require('superagent'); var cheerio = require('cheerio');var async = require('async');var fs = require('fs');var request = require('request');var page=1; //获取发型师处有分页功能,所以用该变量控制分页var num = 0;//爬取到的信息总条数var storeid = 1;//门店IDconsole.log('爬虫程序开始运行......');function fetchPage(x) {   //封装函数  startRequest(x); }function startRequest(x) {  superagent    .post('http://tweixin.yueyishujia.com/v2/store/designer.json')    .send({       // 请求的表单信息Form data      page : x,       storeid : storeid    })      // Http请求的Header信息    .set('Accept', 'application/json, text/javascript, */*; q=0.01')    .set('Content-Type','application/x-www-form-urlencoded; charset=UTF-8')    .end(function(err, res){           // 请求返回后的处理      // 将response中返回的结果转换成JSON对象      if(err){        console.log(err);      }else{        var designJson = JSON.parse(res.text);        var deslist = designJson.data.designerlist;        if(deslist.length > 0){          num += deslist.length;          // 并发遍历deslist对象          async.mapLimit(deslist, 5,             function (hair, callback) {            // 对每个对象的处理逻辑               console.log('...正在抓取数据ID:'+hair.id+'----发型师:'+hair.name);               saveImg(hair,callback);            },             function (err, result) {              console.log('...累计抓取的信息数→→' + num);            }          );          page++;          fetchPage(page);        }else{          if(page == 1){            console.log('...爬虫程序运行结束~~~~~~~');            console.log('...本次共爬取数据'+num+'条...');            return;          }          storeid += 1;          page = 1;          fetchPage(page);        }      }    });} fetchPage(page);function saveImg(hair,callback){  // 存储图片  var img_filename = hair.store.name+'-'+hair.name + '.png';  var img_class="lazy" data-src = 'http://photo.yueyishujia.com:8112' + hair.avatar; //获取图片的url  //采用request模块,向服务器发起一次请求,获取图片资源  request.head(img_class="lazy" data-src,function(err,res,body){    if(err){      console.log(err);    }else{        request(img_class="lazy" data-src).pipe(fs.createWriteStream('./image/' + img_filename));   //通过流的方式,把图片写到本地/image目录下,并用发型师的姓名和所属门店作为图片的名称。        console.log('...存储id='+hair.id+'相关图片成功!');    }  });  // 存储照片相关信息  var html = '姓名:'+hair.name+'<br>职业:'+hair.jobtype+'<br>职业等级:'+hair.jobtitle+'<br>简介:'+hair.simpleinfo+'<br>个性签名:'+hair.info+'<br>剪发价格:'+hair.cutmoney+'元<br>店名:'+hair.store.name+'<br>地址:'+hair.store.location+'<br>联系方式:'+hair.telephone+'<br>头像:<img class="lazy" data-src='+img_class="lazy" data-src+' >';  fs.appendFile('./data/' +hair.store.name+'-'+ hair.name + '.html', html, 'utf-8', function (err) {    if (err) {      console.log(err);    }  });  callback(null, hair);}

步骤六:运行爬虫程序

输入node hz.js命令运行爬虫程序,效果图如下:

node.js简单爬虫的方法是什么

运行成功后,发型师基本信息以html文件的形式存储在data文件夹中,发型师头像图片存储在image文件夹下。

到此,关于“node.js简单爬虫的方法是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

node.js简单爬虫的方法是什么

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

node.js简单爬虫的方法是什么

这篇文章主要介绍“node.js简单爬虫的方法是什么”,在日常操作中,相信很多人在node.js简单爬虫的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”node.js简单爬虫的方法是什么”的疑惑有所
2023-07-04

基于node.js怎么制作简单爬虫

这篇文章主要讲解了“基于node.js怎么制作简单爬虫”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“基于node.js怎么制作简单爬虫”吧!目标:爬取 http://tweixin.yuey
2023-06-17

Node.js简单实现爬虫代码怎么写

以下是一个简单的Node.js爬虫代码示例:const request = require('request');const cheerio = require('cheerio');// 目标网站的URLconst url = 'h
2023-10-26

JS参数反爬虫的方法是什么

这篇文章主要介绍“JS参数反爬虫的方法是什么”,在日常操作中,相信很多人在JS参数反爬虫的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JS参数反爬虫的方法是什么”的疑惑有所帮助!接下来,请跟着小编
2023-06-02

Python 用Redis简单实现分布式爬虫的方法

Redis通常被认为是一种持久化的存储器关键字-值型存储,可以用于几台机子之间的数据共享平台。 连接数据库 注意:假设现有几台在同一局域网内的机器分别为Master和几个Slaver Master连接时host为localhost即本机的i
2022-06-04

python爬虫获取数据的方法是什么

Python爬虫获取数据的方法有以下几种:1. 使用第三方库:Python有很多强大的第三方库,如Requests、BeautifulSoup、Scrapy等,可以用来实现爬虫功能。使用这些库可以发送HTTP请求、解析HTML页面、抓取数据
2023-10-19

Python Selenium自动化爬虫的方法是什么

本篇内容主要讲解“Python Selenium自动化爬虫的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python Selenium自动化爬虫的方法是什么”吧!简单介绍:Selen
2023-06-28

golang爬虫和Python爬虫的区别是什么

golang爬虫和Python爬虫的区别是:1、Golang具有较高的性能,而Python通常比较慢;2、Golang的语法设计简洁、清晰,而Python的语法简洁、易读易写;3、Golang天生支持并发,而Python的并发性能相对较差;
golang爬虫和Python爬虫的区别是什么
2023-12-12

什么是Python爬虫及用法

什么是Python爬虫及用法,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。在学习爬虫之前我们需要明白的一个问题:爬虫能做什么?爬虫除了能够获取互联网的数据以外还能够帮我们完成很
2023-06-02

Python爬虫所需要的爬虫代理ip是什么

本篇内容主要讲解“Python爬虫所需要的爬虫代理ip是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python爬虫所需要的爬虫代理ip是什么”吧!1 代理类型代理IP一共可以分成4种类型
2023-06-02

python爬虫中分布式爬虫的作用是什么

这篇文章给大家分享的是有关python爬虫中分布式爬虫的作用是什么的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。随着大数据时代的来临,大数据也吸引了越来越多的关注。网络爬虫是一种高效的信息抓取工具,它集成了搜索引
2023-06-15

python网络爬虫方向的第三方库是什么

这篇文章主要介绍“python网络爬虫方向的第三方库是什么”,在日常操作中,相信很多人在python网络爬虫方向的第三方库是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”python网络爬虫方向的第三方库
2023-07-02

python网络爬虫指的是什么

小编给大家分享一下python网络爬虫指的是什么,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!python有哪些常用库python常用的库:1.requesuts;2.scrapy;3.pillow;4.twisted;5
2023-06-14

C语言简单编程的方法是什么

这篇文章主要讲解了“C语言简单编程的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言简单编程的方法是什么”吧!我们将所有的 C 语言要素放置到一份易读的备忘录上。1972 年,
2023-06-16

VB.NET实现闰年的简单方法是什么

VB.NET实现闰年的简单方法是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。想必大家都知道闰年是怎么回事吧,就是四年一闰,百年不闰,四百年再闰。在VB.N
2023-06-17

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录