学习笔记

前言

近期做一个数据抓爬工具,最开始使用的是C#控制台应用,同时正则表达式去过滤数据,看着还行,可每次运行都依附于.net framework很是不爽,于是想整点其他的方法。本人还是比较喜欢javascript的,思来想去决定用服务器端的javascript来试试!

环境、工具准备

1、[必装] 安装nodejs,下载最新nodejs,点击此处

2、[选装] 安装iisnode,以及rewrite,因为我是以IIS作为Server,所以用到了这2个IIS的拓展插件,假如仅仅只是cmd控制台运行node则这第二项忽略

3、附加信息:当安装成功之后,在IIS下回出现URL重写这么个东东

范例实现

我以一个小小的案例来实现这么个功能,咱们去抓下面这个站点的数据测试一下:http://www.jj59.com/

原网站截图如下:

接下来我要做的就是

1、将指定页的列表页中文章的标题与对应链接过滤出来,然后返回json数组

2、将详情页文章标题,作者,创建时间,内容过滤出来,然后返回json对象

具体nodejs代码于运行结果

1 var http = require('http');2 var _url = require('url'); //引用url模块,处理url地址相关操作

3 var cheerio = require("cheerio"); //引用cheerio模块,使在服务器端像在客户端上操作DOM,不用正则表达式

4 var iconv = require('iconv-lite'); //解决编码转换模块

5 var BufferHelper = require('bufferhelper'); //关于Buffer我后面细说

6 /*

7 *最后我需要达到的效果是,给予一个访问地址,形如:http://www.mynode.com?link=www.abc.com&callback=cb8 *我希望可以返回json,也可返回jsonp9 */

10

11 http.createServer(function(req, res) {12 var arg = _url.parse(req.url, true).query; //通过调用url模块,获取查询字符串参数集合

13 var link = arg.link; //获取抓取的link

14 var callback = arg.callback; //回调函数的名称

15 //若没有对link加上http,则补全

16 var protocol = "http";17 if (link.indexOf("http") < 0) {18 link = protocol + "://" +link;19 }20 //抓取页面

21 download(link, function(data) {22 res.writeHead(200, {23 "Content-Type": "text/html;charset=utf-8",24 "Transfer-Encoding": "chunked"

25 });26 var doc =data.toString();27 var $ =cheerio.load(doc);28 var list =[];29 $(".e2 li .title").each(function(i, e) {30 var item = $(e).children("a").last();31 var title =item.text();32 var link = item.attr("href");33 list.push({ "title": title, "link": link });34 });35 var jsonText =JSON.stringify(list);36 if(callback) {37 res.write(callback + "(" + jsonText + ")");38 }39 else{40 res.write(jsonText);41 }42 res.end();43 });44 }).listen(process.env.PORT);45

46 //加载第三方页面

47 functiondownload(url, callback) {48 http.get(url, function(res) {49 var bufferHelper = new BufferHelper(); //解决中文编码问题

50 res.on('data', function(chunk) {51 bufferHelper.concat(chunk);52 });53 res.on("end", function() {54 //注意,此编码必须与抓取页面的编码一致,否则会出现乱码,也可以动态去识别

55 var val = iconv.decode(bufferHelper.toBuffer(), 'gb2312');56 callback(val);57 });58 }).on("error", function() {59 callback(null);60 });61 }

View Code

1、列表页json列表

请求的url:http://myurl?link=http://www.jj59.com/jingpinwenzhang/list_68_3.html&callback=cb

cb([{"title":"流金岁月 书香伴行","link":"http://www.jj59.com/jingpinwenzhang/096929.html"},{"title":"奋斗书写无悔青春","link":"http://www.jj59.com/jingdianmeiwen/088963.html"},{"title":"如果他喜欢你,就不会暧昧不清;如果他不再联系你,别为他找理由","link":"http://www.jj59.com/jingpinwenzhang/082919.html"},{"title":"月下彷徨,你已不复当年模样","link":"http://www.jj59.com/jingdianmeiwen/082295.html"},{"title":"话糙理不糙的农家话(4)","link":"http://www.jj59.com/jingpinwenzhang/080410.html"},{"title":"浮生若梦,掩袖一笑弹指间","link":"http://www.jj59.com/jingdianmeiwen/078491.html"},{"title":"转瞬柔,似是非","link":"http://www.jj59.com/jingpinwenzhang/078002.html"},{"title":"春天","link":"http://www.jj59.com/jingdianmeiwen/077439.html"},{"title":"当生活的“美”成为一种遗憾","link":"http://www.jj59.com/jingdianmeiwen/074365.html"},{"title":"中秋节的起源、食俗、古诗佳句","link":"http://www.jj59.com/jingpinwenzhang/043440.html"}])

2、详情页json对象

请求的url:http://myurl?link=http://www.jj59.com/jingpinwenzhang/082919.html&callback=cb

cb({"title":"如果他喜欢你,就不会暧昧不清;如果他不再联系你,别为他找理由","date":"2011-05-12","auth":"午夜未殇","content":"  1、如果他被动矜持。\r\n  \r\n  “也许他不想破坏我们的友谊”\r\n  \r\n  “也许他害羞”“也许他自卑”\r\n  \r\n  “也许他只是不知道怎么联络我”……\r\n  \r\n  Gerg说,在整个人类历史进程中,\r\n  \r\n  任何一个男的都会为了接近你而不在乎断送“友情”,\r\n  \r\n  他也不可能因为害羞和自卑而害怕得不敢追你,\r\n  \r\n  他唯一“害怕”的只是他对你是那么的“无动于衷”,\r\n  \r\n  他不会不知道怎么联络你,手机,email,IM,SNS,twitter……\r\n  \r\n  他可以动用他的眼睛、嘴巴、大脑、关系网、google找到你——除非他不想找到你。\r\n  \r\n  也许有人提倡这已经不是石器时代了,\r\n  \r\n  女孩子去主动追求看上的人吧,\r\n  \r\n  但是相信真正喜欢你的人一定不会让你费尽周折去找他——因为他会主动送上门来。\r\n  \r\n  2、如果他答应你的事却没有做到,哪怕那只是一个电话。\r\n  \r\n  “他真的很忙所以忘了”“至少他真的与我道歉了”……他很忙,\r\n  \r\n  即将就任美国总统,一个小时好几亿的生意要谈,忙得快疯了,\r\n  \r\n  一天根本抽不出时间与你打电话,忙得真疯呀。\r\n  \r\n  有手机、有快速拨号、甚至有语音拨号,\r\n  \r\n  有时压根没想打电话,电话就从裤兜里拨出去了,\r\n  \r\n  为什么没有时间打电话。\r\n  \r\n  如果真的喜欢你就不会忘记,如果忘记说明他不在乎你失望。\r\n  \r\n  “忙”就是恋爱上的大规模杀伤性武器,是“混蛋”的同义词,\r\n  \r\n  混蛋就是用忙敷衍你的那个人。\r\n  \r\n  ——(心智健全的)男人知道什么叫“轻重缓急”,至于道歉?\r\n  \r\n  噢,没有时间听他胡说八道。\r\n  \r\n  3、如果他暧昧不清。\r\n  \r\n  “他以前受过伤”“他现在生活很混乱”\r\n  \r\n  “他刚刚分手/离婚,他想慢慢来”“他习惯了自由”……\r\n  \r\n  这些全是都市神话,用来对付男人不喜欢的女孩,\r\n  \r\n  如果他喜欢你,就不会暧昧不清,就会昭告天下对你的所有权,\r\n  \r\n  他不愿意见你的朋友和家人,\r\n  \r\n  说因为是和你在一起而不是要和***谈恋爱,\r\n  \r\n  他不愿意带你走进他的圈子,说因为这只是两个人的事,\r\n  \r\n  如果他用以上种种借口解释你们之间的暧昧,\r\n  \r\n  那么请自动翻译成“我只想用你来消磨时间”“我不太喜欢你”。\r\n  \r\n  4、如果他不愿意与你太亲近。\r\n  \r\n  Gerg说得无比直接,\r\n  \r\n  “我是男人,如果我喜欢你,我就吻你,会想看你穿内衣和不穿内衣的样子。”,\r\n  \r\n  虽然觉得很囧很寒,但是想想也是实话吧,\r\n  \r\n  如果喜欢你就应该是喜欢你的内在和外在,\r\n  \r\n  难道你要一个喜欢你的人与你说“我很爱你,让我成为你的心灵之友吧”……\r\n  \r\n  我估计柏拉图他老人家也不会这么说。\r\n  \r\n  5、如果他背叛你。\r\n  \r\n  “他喝多了”“那只是偶尔出现的意外”“他是不小心的”……\r\n  \r\n  Gerg说得很对,背叛没有借口。\r\n  \r\n  背叛这种事情是不会“不小心就发生”的,\r\n  \r\n  他不可能说“噢,我不小心摔了一跤,正好摔到别人床上去了。”\r\n  \r\n  明知会破坏恋爱中的规矩还要去实施,\r\n  \r\n  你应该直接把他甩掉,最糟糕的是有人可能因此怀疑自己的魅力,\r\n  \r\n  是不是应该整容是不是应该减肥,\r\n  \r\n  Gerg说得很酷:“你需要减掉的不是20磅,\r\n  \r\n  而是175磅——你那没出息的男朋友的体重。”\r\n  \r\n  6、如果他都喝得醉醺醺才来找你。\r\n  \r\n  他酗酒、或者吸毒(这个在国内应该不普遍),\r\n  \r\n  而不愿意为你改变,那么就该离开,因为长远的生活是需要清醒的。\r\n  \r\n  7、如果时机成熟但他依然不想结婚。\r\n  \r\n  “也许是我思想太不开放”“他受到童年家庭阴影”“他还没准备好”……\r\n  \r\n  许多男人、女人、心理学家、社会学家、人类学家、女权主义者...\r\n  \r\n  都可以滔滔不绝的进行一场批判婚姻制度的讲座,\r\n  \r\n  告诉你婚姻是落后的制度是古老的财务契约,\r\n  \r\n  可是很抱歉,首先你要搞清楚“不想结婚”可能仅仅意味着“不想和你结婚”,\r\n  \r\n  那些说“不想结婚”人最后一定会结婚,只是不是和你。\r\n  \r\n  8、如果他不断的与你分手,然后又来找你和好。\r\n  \r\n  首先请保持风度,不要再打电话传简讯给他,如果分手,那就是分手。\r\n  \r\n  你不要觉得只要他回来找你,你就可以继续跟他聊天、见面、看电影,\r\n  \r\n  为他做饭、买礼物、刻CD、喂鱼,问候他的父母和朋友,\r\n  \r\n  偷用他的语音信箱查询他的通话记录。。。。。\r\n  \r\n  真正喜欢你的人不会要和你分手,不会翻来覆去的折腾你,\r\n  \r\n  所以麻烦你清醒点,除非你想成为悠悠球冠军小姐。\r\n  \r\n  9、如果他突然莫名其妙的消失了。\r\n  \r\n  不要花费巨大的精力来解决“失踪男人之谜”,\r\n  \r\n  无论你找出了各种各样可以安慰自己的证据和借口,\r\n  \r\n  唯一的事实是,他不再想和你在一起,\r\n  \r\n  并且没有胆量和你说清楚。\r\n  \r\n  请相信,没有什么秘密——他配不上你。\r\n  \r\n  10、如果他是已婚。\r\n  \r\n  没什么好说的,至少在他离婚之前。\r\n  \r\n  如果你还想不通,那么大概应该报警——有人把大脑丢了。\r\n  \r\n  有时我们宁愿相信一个男人太害怕、太紧张、太自卑、太圣洁、\r\n  \r\n  太爱前女友、太敏感、太恋母、太忙、童年阴影太多、\r\n  \r\n  家庭压力太大、太累、太疯、晒得太黑、太有自杀倾向……\r\n  \r\n  却不愿意看清很简单的事实,\r\n  \r\n  是的,他不是太忙,不是受过伤,\r\n  \r\n  不是有童年阴影,不是遇到了地震洪水,\r\n  \r\n  不是要就任美国总统,不是脑震荡得了短暂性失忆,\r\n  \r\n  不是手机掉进了火锅,他不是有健忘症,\r\n  \r\n  他也不是死了——他只是没有那么喜欢你而已。\r\n  \r\n  "})

View Code

总结

1、通过使用nodejs实现抓数据,发现就是不一样,就像原始的用javascript操作DOM一样方便,这得益于模块cheerio,它是nodejs特别为服务器定制,快速灵活实施的Jquery核心实现。cheerio工作于DOM模型上,且解析、操作、呈送都很高效,据基准测试:cheerio大约比JsDom快8倍。

cheerio的使用:

1 //方式一

2 var cheerio = require("cheerio");3 var $ =cheerio.load(doc);4 $("p").attr("id","test");5

6 //方式二

7 var $= require("cheerio");8 $("p").attr("id","test");

2、另外一个就是iconv-lite,它的作用就是解决编码问题,可以认为是一种标准字符集转换接口,用于在不同字符集编码之间进行转换,注意:nodejs自带的toString()方法是不能解决中文编码问题的。

官方资料:iconv-lite支持的编码包括node.js原生编码:utf8, ucs2, ascii, binary, base64;同时支持广泛使用的单字节编码:Windows 125x family, ISO-8859 family, IBM/DOS codepages, Macintosh family, KOI8 family, latin1, us-ascii;多字节编码:gbk, gb2313, Big5, cp950。

iconv-lite的使用:

1 var iconv = require('iconv-lite');2 //将nodejs的原生编码转换成其他编码

3 var val = iconv.decode(bufferHelper.toBuffer(), 'gb2312');

3、在做字符处理,特别是GB2312,GBK格式,例如GBK格式英文占用1个字节,汉字占2个字节,当执行ondata时,匿名函数的参数chunk其实是一个Buffer对象,如下代码:

1 res.on('data', function(chunk) {2 bufferHelper.concat(chunk);3 });

当你换成用result+=chunk时,其实隐式的将chunk做了toStrinig()处理,于是到了最后,不管你用下面哪种方式都会报错

1.variconv =newIconv('GBK','UTF-8');iconv.convert(result).toString();

2.iconv.decode(result , 'gb2312');

原因:你对Buffer对象做了加法操作,字符截断,导致解码出错。

bufferhelper的使用:

1 var BufferHelper = require('bufferhelper');2 var bufferHelper = newBufferHelper();3 bufferHelper.concat(chunk);

结束,睡觉

------如果你觉得此文对你有所帮助,别忘了点击下右下角的推荐咯,谢谢!------

node爬取某app数据_使用NodeJs,实现数据抓取相关推荐

  1. r语言抓取网页数据_使用R进行网页抓取的简介

    r语言抓取网页数据 by Hiren Patel 希伦·帕特尔(Hiren Patel) 使用R进行网页抓取的简介 (An introduction to web scraping using R) ...

  2. cookie追加数据_集算器 SPL 抓取网页数据

    [摘要] 集算器 SPL 支持抓取网页数据,根据抓取定义规则,可将网页数据下载到在本地进行统计分析.具体定义规则要求.使用详细情况,请前往乾学院:集算器 SPL 抓取网页数据! 网站上的数据源是我们进 ...

  3. python爬虫实时更新数据_爬虫的增量式抓取和数据更新

    一些想法 页面爬的多了,量上去了之后,就会遇到其他的问题,其实不管做什么技术量大了都会有问题.一般情况下,我认为解决"大量"问题的思路有两个:一种是着力于优化系统的能力,让原本只能 ...

  4. python爬取小说出现乱码_详解Python解决抓取内容乱码问题(decode和encode解码)

    一.乱码问题描述 经常在爬虫或者一些操作的时候,经常会出现中文乱码等问题,如下 原因是源网页编码和爬取下来后的编码格式不一致 二.利用encode与decode解决乱码问题 字符串在Python内部的 ...

  5. python爬虫怎么爬同一个网站的多页数据-如何用Python爬数据?(一)网页抓取

    如何用Python爬数据?(一)网页抓取 你期待已久的Python网络数据爬虫教程来了.本文为你演示如何从网页里找到感兴趣的链接和说明文字,抓取并存储到Excel. 需求 我在公众号后台,经常可以收到 ...

  6. python爬网站数据实例-如何用Python爬数据?(一)网页抓取

    如何用Python爬数据?(一)网页抓取 你期待已久的Python网络数据爬虫教程来了.本文为你演示如何从网页里找到感兴趣的链接和说明文字,抓取并存储到Excel. 需求 我在公众号后台,经常可以收到 ...

  7. vs用Python爬数据?(一)网页抓取

    你期待已久的Python网络数据爬虫教程来了.本文为你演示如何从网页里找到感兴趣的链接和说明文字,抓取并存储到Excel. (由于微信公众号外部链接的限制,文中的部分链接可能无法正确打开.如有需要,请 ...

  8. asp.net 获取全部在线用户_提取在线数据的9个最佳网页抓取工具

    Web Scraping工具专门用于从网站中提取信息.它们也被称为网络收集工具或Web数据提取工具. Web Scraping工具可以在各种场景中用于无限目的. 比如: 1.收集市场研究数据 网络抓取 ...

  9. oracle 数据库中执行数据库语句能找到数据,但是程序中却抓取不到

    oracle 数据库中执行数据库语句能找到数据,但是程序中却抓取不到? 原因:数据库中插入数据时没有commit,执行COMMIT后就可以查询到. 转载于:https://www.cnblogs.co ...

  10. stata抓取html,(5)详解 stata 爬虫抓取网页上的数据 part 1

    *案例:抓取 http://www.tjcn.org 中国统计信息网上前50页(每页包含20个市的数据)的1000个地区的GDP数据.使用stata版本为 stata13,与12版本和14版本都不兼容 ...

最新文章

  1. 设计模式 — 行为型模式 — 解释器模式
  2. 2021年北京高校数学建模校际联赛题目_B
  3. SSM+Maven整合时在Eclipse中使用Mybatis逆向工程自动生成代码
  4. BZOJ2329: [HNOI2011]括号修复(Splay)
  5. QT子文件的建立和调用
  6. 设计模式之——静态代理模式
  7. 层级分类(续)-使用B-CNN(Branch CNN)实现
  8. 游戏资源提取软件介绍
  9. 公式图片识别转换工具
  10. 01背包问题——大背包:
  11. [UE4]让Spline具象化
  12. GO分析和KEGG分析都是啥?
  13. Rate Limiting速率限制
  14. C# Parellel.For 和 Parallel.ForEach
  15. 图片·21312312
  16. 湘南巷子商城“0元购”逆袭上线
  17. 机器人或自动化类简历面试小技巧
  18. 在系统里放一只“猴子”,阿里疯了吗?
  19. 各版本cuDNN驱动下载地址 无需注册
  20. “哥伦布”华为,与智能联接新大陆

热门文章

  1. 数字孪生坦克装置,让智慧战场监管透明化
  2. 数字孪生银行项目经典案例
  3. Excel数据透视表经典教程八《创建单页/自定义字段透视表》
  4. 二十四节气-白露 | 白露至,秋实美
  5. 如何进入大数据领域,学习路线是什么?
  6. 要知道宇宙有多少星球,比数清地球上的沙子数量还要困难!
  7. 搭建kafka集群并使用springboot 整合
  8. 三、elasticsearch 实际应用(碎片篇)
  9. 婚礼请柬邀请函电子版制作模板,520一起来参加婚礼吧!
  10. 卷积神经网络(conv2d参数含义、卷积层、池化层)